拦截器的实现分为两步:
HandlerInterceptor
接口并重写 preHandle
方法WebMvcConfigurer
的 addInterceptors
方法中)public class LoginInterceptor implements HandlerInterceptor {
@Override
public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
HttpSession session = request.getSession(false);
if (session != null && session.getAttribute("user") != null) {
return true;
}
response.setStatus(401);
return false;
}
}
@Configuration
public class AppConfig implements WebMvcConfigurer {
@Override
public void addInterceptors(InterceptorRegistry registry) {
registry.addInterceptor(new LoginInterceptor())
.addPathPatterns("/**") // 拦截所有的接口
.excludePathPatterns("/**/login.html"); // 排除的接口
}
}
addPathPatterns
: 表示要拦截的URL.excludePathPatterns
: 表示需要排除的URL
Spring 中的拦截器是通过 动态代理 和 环绕通知 的思想实现的.
统一异常处理使用的是 @ControllerAdvice + @ExceptionHandler
来实现的,
@ControllerAdvice
表示控制器通知类,@ExceptionHandler
是异常处理器,两个结合表示当出现异常的时候执行某个通知, 也就是执行某个方法事件
@ControllerAdvice
@ResponseBody
public class ErrorAdvice {
@ExceptionHandler(NullPointerException.class)
public Object nullPointerException(NullPointerException e) {
HashMap<String, Object> map = new HashMap<>();
map.put("success",200);
map.put("status",-1);
map.put("message","空指针异常!");
return map;
}
}
@RestController
@RequestMapping("/user")
public class UserController {
@RequestMapping("/hi")
public String say() {
Object object = null;
int i = object.hashCode();
return "Hello";
}
}
统一的数据返回格式可以使用 @ControllerAdvice + ResponseBodyAdvice 的方式实现.
@ControllerAdvice
ResponseBodyAdvice
接口, 并重写beforeBodyWrite
方法@ControllerAdvice
public class ResponseAdvice implements ResponseBodyAdvice {
/**
* 内容是否重写, 返回true表示重写
*/
@Override
public boolean supports(MethodParameter returnType, Class converterType) {
return true;
}
@Override
public Object beforeBodyWrite(Object body, MethodParameter returnType, MediaType selectedContentType, Class selectedConverterType, ServerHttpRequest request, ServerHttpResponse response) {
// 统一数据格式的封装
HashMap<String, Object> result = new HashMap<>();
result.put("success",200);
result.put("status",1);
result.put("data",body);
return result;
}
}
@RestController
@RequestMapping("/user")
public class UserController {
@RequestMapping("/index")
public Object index() {
User user = new User();
user.setUsername("SpringAOP");
user.setPassword("123456");
return user;
}
}
版权说明 : 本文为转载文章, 版权归原作者所有 版权申明
原文链接 : https://wangzhi430.blog.csdn.net/article/details/125292782
内容来源于网络,如有侵权,请联系作者删除!