|  | @@ -4,6 +4,9 @@ import java.io.IOException;
 | 
											
												
													
														|  |  import javax.servlet.ServletException;
 |  |  import javax.servlet.ServletException;
 | 
											
												
													
														|  |  import javax.servlet.http.HttpServletRequest;
 |  |  import javax.servlet.http.HttpServletRequest;
 | 
											
												
													
														|  |  import javax.servlet.http.HttpServletResponse;
 |  |  import javax.servlet.http.HttpServletResponse;
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +import com.ylx.common.core.domain.model.WxLoginUser;
 | 
											
												
													
														|  | 
 |  | +import com.ylx.framework.web.service.WxTokenService;
 | 
											
												
													
														|  |  import org.springframework.beans.factory.annotation.Autowired;
 |  |  import org.springframework.beans.factory.annotation.Autowired;
 | 
											
												
													
														|  |  import org.springframework.context.annotation.Configuration;
 |  |  import org.springframework.context.annotation.Configuration;
 | 
											
												
													
														|  |  import org.springframework.security.core.Authentication;
 |  |  import org.springframework.security.core.Authentication;
 | 
											
										
											
												
													
														|  | @@ -25,11 +28,14 @@ import com.ylx.framework.web.service.TokenService;
 | 
											
												
													
														|  |   * @author ylx
 |  |   * @author ylx
 | 
											
												
													
														|  |   */
 |  |   */
 | 
											
												
													
														|  |  @Configuration
 |  |  @Configuration
 | 
											
												
													
														|  | -public class LogoutSuccessHandlerImpl implements LogoutSuccessHandler
 |  | 
 | 
											
												
													
														|  | -{
 |  | 
 | 
											
												
													
														|  | 
 |  | +public class LogoutSuccessHandlerImpl implements LogoutSuccessHandler {
 | 
											
												
													
														|  |      @Autowired
 |  |      @Autowired
 | 
											
												
													
														|  |      private TokenService tokenService;
 |  |      private TokenService tokenService;
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +    @Autowired
 | 
											
												
													
														|  | 
 |  | +    private WxTokenService wxTokenService;
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  |      /**
 |  |      /**
 | 
											
												
													
														|  |       * 退出处理
 |  |       * 退出处理
 | 
											
												
													
														|  |       *
 |  |       *
 | 
											
										
											
												
													
														|  | @@ -37,16 +43,26 @@ public class LogoutSuccessHandlerImpl implements LogoutSuccessHandler
 | 
											
												
													
														|  |       */
 |  |       */
 | 
											
												
													
														|  |      @Override
 |  |      @Override
 | 
											
												
													
														|  |      public void onLogoutSuccess(HttpServletRequest request, HttpServletResponse response, Authentication authentication)
 |  |      public void onLogoutSuccess(HttpServletRequest request, HttpServletResponse response, Authentication authentication)
 | 
											
												
													
														|  | -            throws IOException, ServletException
 |  | 
 | 
											
												
													
														|  | -    {
 |  | 
 | 
											
												
													
														|  | 
 |  | +            throws IOException, ServletException {
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  |          LoginUser loginUser = tokenService.getLoginUser(request);
 |  |          LoginUser loginUser = tokenService.getLoginUser(request);
 | 
											
												
													
														|  | -        if (StringUtils.isNotNull(loginUser))
 |  | 
 | 
											
												
													
														|  | -        {
 |  | 
 | 
											
												
													
														|  | 
 |  | +        if (StringUtils.isNotNull(loginUser)) {
 | 
											
												
													
														|  |              String userName = loginUser.getUsername();
 |  |              String userName = loginUser.getUsername();
 | 
											
												
													
														|  |              // 删除用户缓存记录
 |  |              // 删除用户缓存记录
 | 
											
												
													
														|  |              tokenService.delLoginUser(loginUser.getToken());
 |  |              tokenService.delLoginUser(loginUser.getToken());
 | 
											
												
													
														|  |              // 记录用户退出日志
 |  |              // 记录用户退出日志
 | 
											
												
													
														|  |              AsyncManager.me().execute(AsyncFactory.recordLogininfor(userName, Constants.LOGOUT, MessageUtils.message("user.logout.success")));
 |  |              AsyncManager.me().execute(AsyncFactory.recordLogininfor(userName, Constants.LOGOUT, MessageUtils.message("user.logout.success")));
 | 
											
												
													
														|  | 
 |  | +        }else{
 | 
											
												
													
														|  | 
 |  | +            WxLoginUser wxUser = wxTokenService.getWxUser(request);
 | 
											
												
													
														|  | 
 |  | +            if (StringUtils.isNotNull(wxUser)) {
 | 
											
												
													
														|  | 
 |  | +                String userName = wxUser.getUsername();
 | 
											
												
													
														|  | 
 |  | +                // 删除用户缓存记录
 | 
											
												
													
														|  | 
 |  | +                tokenService.delLoginUser(wxUser.getToken());
 | 
											
												
													
														|  | 
 |  | +                // 记录用户退出日志
 | 
											
												
													
														|  | 
 |  | +                AsyncManager.me().execute(AsyncFactory.recordLogininfor(userName, Constants.LOGOUT, MessageUtils.message("user.logout.success")));
 | 
											
												
													
														|  | 
 |  | +            }
 | 
											
												
													
														|  |          }
 |  |          }
 | 
											
												
													
														|  |          ServletUtils.renderString(response, JSON.toJSONString(AjaxResult.success(MessageUtils.message("user.logout.success"))));
 |  |          ServletUtils.renderString(response, JSON.toJSONString(AjaxResult.success(MessageUtils.message("user.logout.success"))));
 | 
											
												
													
														|  |      }
 |  |      }
 |