sa-token/sa-token-demo-springboot/src/main/java/com/pj/test/TopController.java

54 lines
1.7 KiB
Java
Raw Normal View History

2020-02-05 00:31:51 +08:00
package com.pj.test;
import java.io.IOException;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.springframework.web.bind.annotation.ControllerAdvice;
import org.springframework.web.bind.annotation.ExceptionHandler;
import org.springframework.web.bind.annotation.ModelAttribute;
import com.fasterxml.jackson.databind.ObjectMapper;
import cn.dev33.satoken.exception.NotLoginException;
import cn.dev33.satoken.exception.NotPermissionException;
/**
* 加强版控制器
*/
2020-05-02 15:19:55 +08:00
@ControllerAdvice // 可指定包前缀,比如:(basePackages = "com.pj.admin")
2020-02-05 00:31:51 +08:00
public class TopController {
// 在每个控制器之前触发的操作
@ModelAttribute
public void get(HttpServletRequest request) throws IOException {
}
// 全局异常拦截(拦截项目中的所有异常)
@ExceptionHandler
public void handlerException(Exception e, HttpServletRequest request, HttpServletResponse response)
throws Exception {
2020-05-02 15:19:55 +08:00
// 打印堆栈,以供调试
e.printStackTrace();
2020-02-05 00:31:51 +08:00
2020-05-02 15:19:55 +08:00
// 不同异常返回不同状态码
AjaxJson aj = null;
if (e instanceof NotLoginException) { // 如果是未登录异常
aj = AjaxJson.getNotLogin();
} else if(e instanceof NotPermissionException) { // 如果是权限异常
2020-02-05 00:31:51 +08:00
NotPermissionException ee = (NotPermissionException) e;
2020-05-02 15:19:55 +08:00
aj = AjaxJson.getNotJur("无此权限:" + ee.getCode());
} else { // 普通异常, 输出500 + 异常信息
aj = AjaxJson.getError(e.getMessage());
2020-02-05 00:31:51 +08:00
}
2020-05-02 15:19:55 +08:00
// 输出到客户端
response.setContentType("application/json; charset=utf-8"); // http说明我要返回JSON对象
response.getWriter().print(new ObjectMapper().writeValueAsString(aj));
2020-02-05 00:31:51 +08:00
}
}