请稍等 ...
×

采纳答案成功!

向帮助你的同学说点啥吧!感谢那些助人为乐的人

token过期捕获到ExpiredJwtException,如何自定义异常到前端?

如下图,当token过期,捕获到ExpiredJwtException异常,服务器返回500状态码。如何修改返回的http状态码,并返回到前端?
图片描述

正在回答 回答被采纳积分+3

2回答

大目 2019-11-28 19:14:01

您好,Spring的全局异常管理,是管不到Filter的哈。

如果您使用Filter的话,那么得将异常try...catch...一下,当发生SecurityException、ExpiredJwtException和IllegalArgumentException时,返回您想要返回的消息体即可。

返回JSON的示例代码如下:

response.setCharacterEncoding("UTF-8");
response.setContentType("application/json; charset=utf-8");
PrintWriter out = null ;
try{
JSONObject res = new JSONObject();
res.put("success","false");
res.put("msg","xxxx");
out = response.getWriter();
out.append(res.toString());
return false;
}
catch (Excepton e){
e.printStackTrace();
response.sendError(500);
return false;

这其实是一个Spring MVC领域的基础问题哈。

Filter无法被Spring MVC管理,得基于Servlet规范自己写返回。

--------

如果您希望使用Spring的全局异常管理的话,可以:

  1. 像视频一样,用AOP玩儿;

  2. 改用拦截器,拦截器是Spring MVC里面的东西,发生异常能够被Spring的全局异常管理所管理到。

0 回复 有任何疑惑可以回复我~
大目 2019-11-28 17:20:51
您好,这个问题在视频后面有解答的哈。简单来说,就是借助spring提供的全局异常管理,统一地处理各种登录,授权相关的异常。 统一处理异常的相关代码在这里:https://git.imooc.com/coding-358/content-center/src/master/src/main/java/com/itmuch/contentcenter/auth/GlobalExceptionErrorHandler.java 祝您学习愉快!
0 回复 有任何疑惑可以回复我~
  • 提问者 zha123 #1
    GlobalExceptionErrorHandler应该捕获哪个异常?SecurityException、ExpiredJwtException和IllegalArgumentException都捕获不到
    回复 有任何疑惑可以回复我~ 2019-11-28 17:51:39
  • 提问者 zha123 #2
    接上一条回复:我是在filter中验证token是否合法。@RestControllerAdvice捕获不到的情况下,如何返回ResponseEntity方式返回?
    回复 有任何疑惑可以回复我~ 2019-11-28 18:09:39
问题已解决,确定采纳
还有疑问,暂不采纳
意见反馈 帮助中心 APP下载
官方微信