如何解决Spring Boot中的跨域资源共享问题?

2026-05-28 07:511阅读0评论SEO资讯
  • 内容介绍
  • 文章标签
  • 相关推荐

本文共计1140个文字,预计阅读时间需要5分钟。

如何解决Spring Boot中的跨域资源共享问题?

本文主要介绍了Spring Boot中跨域问题的解决方案,通过示例代码简要展示了实现方法,对有需要学习的读者具有一定的参考价值。关于Spring Boot中的跨域问题,以下是一些基本内容:

1. 跨域问题定义:跨域问题是指浏览器同源策略限制下的资源请求问题。当发起请求的域、协议和端口与资源所在域不一致时,浏览器会阻止这种请求。

2. 解决方案:Spring Boot提供了多种解决跨域问题的方法,以下是一种常见方式:

- 配置拦截器:在Spring Boot中,可以通过配置拦截器来处理跨域请求。 java @Bean public HandlerInterceptorRegistration addInterceptor() { HandlerInterceptorRegistration registration=registry.addInterceptor(new HandlerInterceptorAdapter() { @Override public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception { response.setHeader(Access-Control-Allow-Origin, *); response.setHeader(Access-Control-Allow-Methods, GET, POST, PUT, DELETE, OPTIONS); response.setHeader(Access-Control-Allow-Headers, Content-Type, X-Requested-With); return true; } }); return registration; }

3. 示例代码:以上代码中,`addInterceptor`方法定义了一个拦截器,用于设置响应头,允许跨域请求。

4. 参考价值:对于有学习Spring Boot或从事相关工作的朋友来说,这篇文章提供了一种实用的跨域问题解决方案,具有一定的参考和学习价值。

5. 友情提示:如果您需要更详细的了解Spring Boot中的跨域问题,建议查阅官方文档或相关技术博客,以获得更全面的信息。

这篇文章主要介绍了springboot跨域问题解决方案,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下

springboot中的跨域问题,如果不注意的话,容易造成错误,本次springboot版本为2.13

前端错误信息:

Access to XMLHttpRequest at 'localhost:8080/user/loginOn' from origin 'localhost:8082' has been blocked by CORS policy:
Response to preflight request doesn't pass access control check: No 'Access-Control-Allow-Origin' header is present on the requested resource.

第一种:是在每个Controller里,加上注解:@CrossOrigin

import javax.validation.Valid; @CrossOrigin @RestController @RequestMapping("/user") public class UserController{

也可以在方法上加上,比如这样,这样针对具体的方法

@CrossOrigin @ApiOperation(value = "用户登录",notes = "") @PostMapping("/loginOn") public ResponseMessage loginOn(@RequestBody @Valid UserReq userReq){

每一个Controller这样写也是很麻烦。

第二种:是实现WebMvcConfigurer接口,在接口中进行跨域支持

以前可以继承WebMvcConfigurerAdapter,springboot2.x版本已经将其@Deprecated

我们直接实现接口:

@Configuration public class WebConfig implements WebMvcConfigurer { /** * 跨域支持 * @param registry */ @Override public void addCorsMappings(CorsRegistry registry) { registry.addMapping("/**") .allowedOrigins("*") .allowCredentials(true) .allowedMethods("GET", "POST", "DELETE", "PUT") .maxAge(3600 * 24); }

但使用这种方法,我今天遇到一个坑,我准备在拦截器里面对用户的请求进行拦截

@Component public class RequestInterceptor implements HandlerInterceptor { @Override public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception { Object loginUser = request.getSession().getAttribute("token"); if(loginUser == null){         //自定义的异常类,这里抛出异常,交给全局异常捕捉类处理 throw new ServiceException("没有权限,请先登录!"); }else{ return true; } } @Override public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception { } @Override public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception { } }

全局异常捕捉类:

@RestControllerAdvice public class GlobleExceptionHandler { @ExceptionHandler(value = ServiceException.class) public ResponseMessage caughtException(ServiceException e){ return new ResponseMessage(e.getMsg()); } }

ResponseMessage 是自定义的统一的响应信息类:

ResponseMessage

@Data public class ResponseMessage { private Integer Code; private String msg; private Integer count; private Object data; public ResponseMessage(Object data) { this.data = data; } public ResponseMessage(String msg) { this.msg = msg; } public ResponseMessage(Integer code, String msg) { Code = code; this.msg = msg; } public ResponseMessage(Integer code, String msg, Integer count) { Code = code; this.msg = msg; this.count = count; } public ResponseMessage(Integer code, String msg, Integer count, Object data) { Code = code; this.msg = msg; this.count = count; this.data = data; } public static ResponseMessage success(String msg){ return new ResponseMessage(200,msg); } public static ResponseMessage fail(Integer code,String msg){ return new ResponseMessage(code,msg); } }

通过这样的处理发现,前端一直报跨域异常问题,这时候有了第三种方法

第三种:使用CorsFilter过滤器:

如何解决Spring Boot中的跨域资源共享问题?

写一个MyCorsConfig 配置类

@Configuration public class MyCorsConfig { @Bean public CorsFilter corsFilter() { CorsConfiguration corsConfiguration = new CorsConfiguration(); corsConfiguration.addAllowedOrigin("*"); corsConfiguration.addAllowedHeader("*"); corsConfiguration.addAllowedMethod("*"); corsConfiguration.setAllowCredentials(true); corsConfiguration.setMaxAge(3600L); UrlBasedCorsConfigurationSource source = new UrlBasedCorsConfigurationSource(); source.registerCorsConfiguration("/**", corsConfiguration); FilterRegistrationBean bean = new FilterRegistrationBean(new CorsFilter(source)); //设置过滤器的顺序 bean.setOrder(0); return new CorsFilter(source); } }

最终解决本次demo的跨域问题。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持易盾网络。

本文共计1140个文字,预计阅读时间需要5分钟。

如何解决Spring Boot中的跨域资源共享问题?

本文主要介绍了Spring Boot中跨域问题的解决方案,通过示例代码简要展示了实现方法,对有需要学习的读者具有一定的参考价值。关于Spring Boot中的跨域问题,以下是一些基本内容:

1. 跨域问题定义:跨域问题是指浏览器同源策略限制下的资源请求问题。当发起请求的域、协议和端口与资源所在域不一致时,浏览器会阻止这种请求。

2. 解决方案:Spring Boot提供了多种解决跨域问题的方法,以下是一种常见方式:

- 配置拦截器:在Spring Boot中,可以通过配置拦截器来处理跨域请求。 java @Bean public HandlerInterceptorRegistration addInterceptor() { HandlerInterceptorRegistration registration=registry.addInterceptor(new HandlerInterceptorAdapter() { @Override public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception { response.setHeader(Access-Control-Allow-Origin, *); response.setHeader(Access-Control-Allow-Methods, GET, POST, PUT, DELETE, OPTIONS); response.setHeader(Access-Control-Allow-Headers, Content-Type, X-Requested-With); return true; } }); return registration; }

3. 示例代码:以上代码中,`addInterceptor`方法定义了一个拦截器,用于设置响应头,允许跨域请求。

4. 参考价值:对于有学习Spring Boot或从事相关工作的朋友来说,这篇文章提供了一种实用的跨域问题解决方案,具有一定的参考和学习价值。

5. 友情提示:如果您需要更详细的了解Spring Boot中的跨域问题,建议查阅官方文档或相关技术博客,以获得更全面的信息。

这篇文章主要介绍了springboot跨域问题解决方案,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下

springboot中的跨域问题,如果不注意的话,容易造成错误,本次springboot版本为2.13

前端错误信息:

Access to XMLHttpRequest at 'localhost:8080/user/loginOn' from origin 'localhost:8082' has been blocked by CORS policy:
Response to preflight request doesn't pass access control check: No 'Access-Control-Allow-Origin' header is present on the requested resource.

第一种:是在每个Controller里,加上注解:@CrossOrigin

import javax.validation.Valid; @CrossOrigin @RestController @RequestMapping("/user") public class UserController{

也可以在方法上加上,比如这样,这样针对具体的方法

@CrossOrigin @ApiOperation(value = "用户登录",notes = "") @PostMapping("/loginOn") public ResponseMessage loginOn(@RequestBody @Valid UserReq userReq){

每一个Controller这样写也是很麻烦。

第二种:是实现WebMvcConfigurer接口,在接口中进行跨域支持

以前可以继承WebMvcConfigurerAdapter,springboot2.x版本已经将其@Deprecated

我们直接实现接口:

@Configuration public class WebConfig implements WebMvcConfigurer { /** * 跨域支持 * @param registry */ @Override public void addCorsMappings(CorsRegistry registry) { registry.addMapping("/**") .allowedOrigins("*") .allowCredentials(true) .allowedMethods("GET", "POST", "DELETE", "PUT") .maxAge(3600 * 24); }

但使用这种方法,我今天遇到一个坑,我准备在拦截器里面对用户的请求进行拦截

@Component public class RequestInterceptor implements HandlerInterceptor { @Override public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception { Object loginUser = request.getSession().getAttribute("token"); if(loginUser == null){         //自定义的异常类,这里抛出异常,交给全局异常捕捉类处理 throw new ServiceException("没有权限,请先登录!"); }else{ return true; } } @Override public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception { } @Override public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception { } }

全局异常捕捉类:

@RestControllerAdvice public class GlobleExceptionHandler { @ExceptionHandler(value = ServiceException.class) public ResponseMessage caughtException(ServiceException e){ return new ResponseMessage(e.getMsg()); } }

ResponseMessage 是自定义的统一的响应信息类:

ResponseMessage

@Data public class ResponseMessage { private Integer Code; private String msg; private Integer count; private Object data; public ResponseMessage(Object data) { this.data = data; } public ResponseMessage(String msg) { this.msg = msg; } public ResponseMessage(Integer code, String msg) { Code = code; this.msg = msg; } public ResponseMessage(Integer code, String msg, Integer count) { Code = code; this.msg = msg; this.count = count; } public ResponseMessage(Integer code, String msg, Integer count, Object data) { Code = code; this.msg = msg; this.count = count; this.data = data; } public static ResponseMessage success(String msg){ return new ResponseMessage(200,msg); } public static ResponseMessage fail(Integer code,String msg){ return new ResponseMessage(code,msg); } }

通过这样的处理发现,前端一直报跨域异常问题,这时候有了第三种方法

第三种:使用CorsFilter过滤器:

如何解决Spring Boot中的跨域资源共享问题?

写一个MyCorsConfig 配置类

@Configuration public class MyCorsConfig { @Bean public CorsFilter corsFilter() { CorsConfiguration corsConfiguration = new CorsConfiguration(); corsConfiguration.addAllowedOrigin("*"); corsConfiguration.addAllowedHeader("*"); corsConfiguration.addAllowedMethod("*"); corsConfiguration.setAllowCredentials(true); corsConfiguration.setMaxAge(3600L); UrlBasedCorsConfigurationSource source = new UrlBasedCorsConfigurationSource(); source.registerCorsConfiguration("/**", corsConfiguration); FilterRegistrationBean bean = new FilterRegistrationBean(new CorsFilter(source)); //设置过滤器的顺序 bean.setOrder(0); return new CorsFilter(source); } }

最终解决本次demo的跨域问题。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持易盾网络。