shikeyin
2024-01-11 65da8373531677b1c37a98f53eaa30c892f35e5a
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
package com.iplatform.security;
 
import com.iplatform.base.UserLoginCache;
import com.iplatform.base.VariableConstants;
import com.iplatform.base.callback.AfterLoginCallback;
import com.iplatform.base.callback.PlatformCallbackPostProcessor;
import com.iplatform.base.util.TokenUtils;
import com.walker.infrastructure.utils.StringUtils;
import com.walker.web.ResponseValue;
import com.walker.web.TokenException;
import com.walker.web.TokenGenerator;
import com.walker.web.UserOnlineProvider;
import com.walker.web.util.ServletUtils;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.security.core.Authentication;
import org.springframework.security.web.authentication.logout.LogoutSuccessHandler;
 
import javax.servlet.ServletException;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
 
public class DefaultLogoutSuccessHandler implements LogoutSuccessHandler {
 
    protected final transient Logger logger = LoggerFactory.getLogger(getClass());
 
    private UserOnlineProvider userOnlineProvider;
 
    private TokenGenerator tokenGenerator;
 
    private UserLoginCache userLoginCache;
 
    public void setUserLoginCache(UserLoginCache userLoginCache) {
        this.userLoginCache = userLoginCache;
    }
 
    public void setTokenGenerator(TokenGenerator tokenGenerator) {
        this.tokenGenerator = tokenGenerator;
    }
 
    public void setUserOnlineProvider(UserOnlineProvider userOnlineProvider) {
        this.userOnlineProvider = userOnlineProvider;
    }
 
    @Override
    public void onLogoutSuccess(HttpServletRequest request
            , HttpServletResponse response, Authentication authentication) throws IOException, ServletException {
        String token = TokenUtils.getAuthorizationToken(request);
        if(StringUtils.isNotEmpty(token)){
            try{
                String data = tokenGenerator.validateToken(token, VariableConstants.TOKEN_SECRET);
                String[] userIdAndKey = TokenUtils.getUserIdAndKey(data);
                this.userOnlineProvider.removeUserPrincipal(userIdAndKey[2]);
                // 2023-07-11 用户登录策略缓存也删除
                this.userLoginCache.removeUserLogin(userIdAndKey[1]);
 
                // 2023-08-18,登录成功回调
                AfterLoginCallback afterLoginCallback = PlatformCallbackPostProcessor.getCallbackObject(AfterLoginCallback.class);
                if(afterLoginCallback != null){
                    afterLoginCallback.onLogout(userIdAndKey[1]);
                }
 
                logger.debug("用户 logout success: " + userIdAndKey[1]);
            } catch (TokenException ex){
                logger.error("logout注销时,token解析错误:" + ex.getMessage() + ", token=" + token, ex);
                if(ex.isExpired()){
                    this.recordLogoutInfo("null", "logout", "token超时,退出操作无法删除缓存");
                } else {
                    this.recordLogoutInfo("null", "logout", "token超时,退出操作异常:" + ex.getMessage());
                }
            }
        }
        ServletUtils.renderString(response, ResponseValue.success("退出成功"));
    }
 
    private void recordLogoutInfo(String loginId, String status, String message){
        logger.debug("异步记录退出日志,后续要补充:" + status + ", " + message);
    }
 
}