Spring Cloud:Security OAuth2 自定义异常响应
2020-12-13 02:01
标签:conf zed uil string map codec cloud lan red # 默认异常响应 在使用 Spring Security Oauth2 登录和鉴权失败时,默认返回的异常信息如下: 这与我们返回的信息格式不一致。如果需要修改这种返回的格式,需要重写相关异常处理类。这里我统一的是资源服务器(网关)的响应格式。 # 自定义异常响应 ## 无效token异常类重写 新增 AuthExceptionEntryPoint.java # 权限不足异常类重写 新增 CustomAccessDeniedHandler.java 修改资源配置类 ResourceServerConfiguration.java 示例代码:https://github.com/BNDong/spring-cloud-examples/tree/master/spring-cloud-zuul/cloud-zuul Spring Cloud:Security OAuth2 自定义异常响应 标签:conf zed uil string map codec cloud lan red 原文地址:https://www.cnblogs.com/geass-jango/p/11022790.html对于客户端开发或者网站开发而言,调用接口返回有统一的响应体,可以针对性的设计界面,代码结构更加清晰,层次也更加分明。
@Component
public class AuthExceptionEntryPoint implements AuthenticationEntryPoint
{
@Override
public void commence(HttpServletRequest request, HttpServletResponse response,
AuthenticationException authException) throws ServletException {
Map
@Component("customAccessDeniedHandler")
public class CustomAccessDeniedHandler implements AccessDeniedHandler {
@Override
public void handle(HttpServletRequest request, HttpServletResponse response,
AccessDeniedException accessDeniedException)
throws IOException, ServletException {
response.setStatus(HttpStatus.OK.value());
response.setHeader("Content-Type", "application/json;charset=UTF-8");
try {
response.getWriter().write(ResultJsonUtil.build(
ResponseCodeConstant.REQUEST_FAILED,
ResponseStatusCodeConstant.OAUTH_TOKEN_DENIED,
ResponseMessageConstant.OAUTH_TOKEN_DENIED
));
} catch (IOException e) {
e.printStackTrace();
}
}
}
@Override
public void configure(ResourceServerSecurityConfigurer resources) {
resources.tokenExtractor(customTokenExtractor);
resources.authenticationEntryPoint(authExceptionEntryPoint)
.accessDeniedHandler(customAccessDeniedHandler);
}
下一篇:奇志思达-微网站前端规则建议
文章标题:Spring Cloud:Security OAuth2 自定义异常响应
文章链接:http://soscw.com/essay/24693.html