SpringSecrurity AuthenticationProvider异常处理

程序设置的全局异常是捕获不到AuthenticationProvider 抛出的异常的,前后端分离后,前端接收到的异常就不是可用的异常信息,那这个时候应该怎么处理异常呢?

1.重写 BasicAuthenticationEntryPoint 类的 commence(HttpServletRequest request, HttpServletResponse response, AuthenticationException authEx)


@Component
@Slf4j
public class KstBasicAuthenticationEntryPoint extends BasicAuthenticationEntryPoint {

	@Override
	public void commence(HttpServletRequest request, HttpServletResponse response, AuthenticationException authEx)
			throws IOException, ServletException {
		response.setStatus(HttpServletResponse.SC_UNAUTHORIZED);
		response.setCharacterEncoding("UTF-8");
		response.setContentType("application/json; charset=utf-8");
		PrintWriter writer = response.getWriter();
		ObjectMapper objectMapper = new ObjectMapper();
		Map<String, String> map = new HashMap<>();
		String[] errMsg = StringUtils.split(StringUtils.defaultString(authEx.getMessage()), ":");
		log.error("用户authentication认证异常:",authEx);
		if (errMsg.length == 2) {
			map.put("code","1");
			map.put("status", errMsg[0]);
			map.put("message", errMsg[1]);
		} else {
			map.put("code","1");
			map.put("status", "1");
			map.put("message"," 错误-未授权");
		}
		
		writer.println(objectMapper.writeValueAsString(map));
		
	}

	@Override
	public void afterPropertiesSet() throws Exception {
		super.afterPropertiesSet();
	}
}

2.完

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值