Spring web开发之使用REST和使用Interceptor和使用Cors
作者:互联网
Spring提供了一个@RestController注解,使用@RestController替代@Controller后,每个方法自动变成API接口方法
Interceptor:
步骤1
实现HandlerInterceptor接口,可以选择实现preHandle()、postHandle()和afterCompletion()方法。
步骤2:使拦截器生效:
@Bean
WebMvcConfigurer createWebMvcConfigurer(@Autowired HandlerInterceptor[] interceptors) {
return new WebMvcConfigurer() {
public void addInterceptors(InterceptorRegistry registry) {
for (var interceptor : interceptors) {
registry.addInterceptor(interceptor);
}
}
...
};
}
异常处理:
基于@ExceptionHandler注解的异常处理方法
@Controller
public class UserController {
@ExceptionHandler(RuntimeException.class)
public ModelAndView handleUnknowException(Exception ex) {
return new ModelAndView("500.html", Map.of("error", ex.getClass().getSimpleName(), "message", ex.getMessage()));
}
...
}
上述代码通过@ExceptionHandler(RuntimeException.class)表示当发生RuntimeException的时候,就自动调用此方法处理。
使用Cors
第一种方法是使用@CrossOrigin注解,可以在@RestController的class级别或方法级别定义一个@CrossOrigin,例如:
@CrossOrigin(origins = "http://local.zy.com:8080")
@RestController
@RequestMapping("/api")
public class ApiController {
...
指定了只允许来自local.zy.com跨域访问,允许多个域访问需要写成数组形式,例如origins = {“http://a.com”, “https://www.b.com”})
第二种方法是在WebMvcConfigurer中定义一个全局CORS配置,下面是一个示例:
@Bean
WebMvcConfigurer createWebMvcConfigurer() {
return new WebMvcConfigurer() {
@Override
public void addCorsMappings(CorsRegistry registry) {
registry.addMapping("/api/**")
.allowedOrigins("http://local.liaoxuefeng.com:8080")
.allowedMethods("GET", "POST")
.maxAge(3600);
// 可以继续添加其他URL规则:
// registry.addMapping("/rest/v2/**")...
}
};
}
这种方式可以创建一个全局CORS配置,如果仔细地设计URL结构,那么可以一目了然地看到各个URL的CORS规则,推荐使用这种方式配置CORS。
标签:web,...,Spring,class,registry,使用,WebMvcConfigurer,com,public 来源: https://blog.csdn.net/zy199701/article/details/113835802