测试用户
2023-04-13 43393f2bb11cbf9e6af40077bbc5284660e8a754
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
package com.common.security.configure;
 
import com.alibaba.fastjson.JSON;
import com.alibaba.fastjson.JSONObject;
import com.common.core.beans.Result;
import com.common.core.enums.ResultCodeEnum;
import com.common.core.exception.BizException;
import org.springframework.security.core.AuthenticationException;
import org.springframework.security.web.AuthenticationEntryPoint;
import org.springframework.stereotype.Component;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
 
/**
 * @author 廖振钦
 * @date 2022-01-17
 * token失效访问接口时,自定义的返回结果
 */
@Component
public class RestAuthenticationEntryPoint  implements AuthenticationEntryPoint {
    @Override
    public void commence(HttpServletRequest request, HttpServletResponse response, AuthenticationException authException) throws IOException {
        response.setCharacterEncoding("UTF-8");
        response.setContentType("application/json");
        response.addHeader("Content-Security-Policy","default-src 'self'");
        response.addHeader("Strict-Transport-Security","max-age=31536000; includeSubdomains");
        response.addHeader("Referrer-Policy","no-referrer-when-downgrade");
        response.addHeader("X-Permitted-Cross-Domain-Policies","all");
        response.addHeader("X-Download-Options","noopen");
        Result res=Result.respErr(ResultCodeEnum.RT_INVALID_TOKEN);
        response.getWriter().println(JSONObject.toJSONString(res));
        response.getWriter().flush();
    }
}