SpringBoot开发秘籍 - 处理跨域请求CORS

简介: CORS(Cross-Origin Resource Sharing)"跨域资源共享",是一个W3C标准,它允许浏览器向跨域服务器发送Ajax请求,打破了Ajax只能访问本站内的资源限制。

CORS(Cross-Origin Resource Sharing)"跨域资源共享",是一个W3C标准,它允许浏览器向跨域服务器发送Ajax请求,打破了Ajax只能访问本站内的资源限制。


在前后分离的架构下,我们经常会遇到跨域CORS问题,在浏览器上的表现就是出现如下一段错误提示:No 'Access-Control-Allow-Origin' header is present on the requested resource.


下面看一下如何让你的SpringBoot项目支持CORS跨域。


SpringBoot处理跨域


在SpringBoot后端处理跨域比较简单,只需要在项目中添加如下一个配置类即可:


/*** Spring Boot 2.0 解决跨域问题* @Author javadaily*/@ConfigurationpublicclassWebMvcConfigurationimplementsWebMvcConfigurer {
@BeanpublicCorsFiltercorsFilter() {
finalUrlBasedCorsConfigurationSourceurlBasedCorsConfigurationSource=newUrlBasedCorsConfigurationSource();
finalCorsConfigurationcorsConfiguration=newCorsConfiguration();
/* 是否允许请求带有验证信息 */corsConfiguration.setAllowCredentials(true);
/* 允许访问的客户端域名 */corsConfiguration.addAllowedOrigin("*");
/* 允许服务端访问的客户端请求头 */corsConfiguration.addAllowedHeader("*");
/* 允许访问的方法名,GET POST等 */corsConfiguration.addAllowedMethod("*");
urlBasedCorsConfigurationSource.registerCorsConfiguration("/**", corsConfiguration);
returnnewCorsFilter(urlBasedCorsConfigurationSource);
 }
}


这里我们在配置类中注入了 CorsFilter并重写了相关配置,大家可以根据自己的业务需求请里面的 * 改成具体的属性值。


通过上面的配置我们基本可以解决后端跨域问题,但是在一些特定情况下还是还出现跨域。


特殊情况


当项目中还有一个自定义过滤器,并且在过滤器中通过 response.getWriter().print()直接向客户端输出返回信息:


adc88a7e6f670520144b6367711f5f4e.png


在这种情况下是不会继续执行后面的过滤器链的。


而在SpringBoot中自定义过滤器的优先级高于WebMvcConfigurer中定义的过滤器,所以此时由于未经过CORS过滤器的处理还是会出现跨域现象。


这种时候我们就需要改写CorsFilter的写法,让其在自定义过滤器之前执行。


解决方法


  • 自定义Cors过滤器


publicclassCustomerCorsFilterextendsCorsFilter {
publicCustomerCorsFilter() {
super(configurationSource());
    }
privatestaticUrlBasedCorsConfigurationSourceconfigurationSource() {
// CORS授权CorsConfigurationconfig=newCorsConfiguration();
config.setAllowCredentials(true);
config.addAllowedOrigin("*");
config.addAllowedHeader("*");
config.addAllowedMethod("*");
config.addExposedHeader(HttpHeaders.SET_COOKIE);
config.setMaxAge(3600L);
UrlBasedCorsConfigurationSourcesource=newUrlBasedCorsConfigurationSource();
source.registerCorsConfiguration("/**", config);
returnsource;
    }
}


  • 通过配置类指定过滤器的优先级


@ConfigurationpublicclassFilterConfig {
@BeanpublicFilterauthFilter(){
returnnewAuthFilter();
    }
/*** WARNING :跨域过滤器,注意执行顺序,必须要在AuthFilter过滤器之后* @return*/@BeanpublicFilterRegistrationBeancorsFilterRegistration() {
FilterRegistrationBeanregistration=newFilterRegistrationBean();
//添加过滤器registration.setFilter(newCustomerCorsFilter());
List<String>urlList=newArrayList<>();
urlList.add("/*");
//设置过滤路径,/*所有路径registration.setUrlPatterns(urlList);
//添加默认参数registration.setName("CorsFilter");
//设置优先级registration.setOrder(-1);
returnregistration;
    }
@BeanpublicFilterRegistrationBeanauthFilterRegistration() {
FilterRegistrationBeanregistration=newFilterRegistrationBean();
//添加过滤器registration.setFilter(authFilter());
List<String>urlList=newArrayList<>();
urlList.add("/*");
//设置过滤路径,/*所有路径registration.setUrlPatterns(urlList);
//添加默认参数registration.setName("authFilter");
//设置优先级registration.setOrder(1);
returnregistration;
    }
}


通过setOrder()方法指定过滤器的执行顺序,用以保证CORS过滤器先入自定义过滤器执行。注意:order的顺序越小优先级越高。


以上,希望对你有所帮助!


End

目录
相关文章
|
1月前
|
前端开发 Java
表白墙/留言墙 —— 初级SpringBoot项目,练手项目前后端开发(带完整源码) 全方位全步骤手把手教学
文章通过一个表白墙/留言墙的初级SpringBoot项目实例,详细讲解了如何进行前后端开发,包括定义前后端交互接口、创建SpringBoot项目、编写前端页面、后端代码逻辑及实体类封装的全过程。
63 3
表白墙/留言墙 —— 初级SpringBoot项目,练手项目前后端开发(带完整源码) 全方位全步骤手把手教学
|
1月前
|
前端开发 Java 数据安全/隐私保护
用户登录前后端开发(一个简单完整的小项目)——SpringBoot与session验证(带前后端源码)全方位全流程超详细教程
文章通过一个简单的SpringBoot项目,详细介绍了前后端如何实现用户登录功能,包括前端登录页面的创建、后端登录逻辑的处理、使用session验证用户身份以及获取已登录用户信息的方法。
146 2
用户登录前后端开发(一个简单完整的小项目)——SpringBoot与session验证(带前后端源码)全方位全流程超详细教程
|
1天前
|
XML Java 数据格式
SpringBoot入门(8) - 开发中还有哪些常用注解
SpringBoot入门(8) - 开发中还有哪些常用注解
8 0
|
2月前
|
前端开发 JavaScript Java
基于Java+Springboot+Vue开发的医院门诊预约挂号系统
基于Java+Springboot+Vue开发的医院门诊预约挂号系统(前后端分离),这是一项为大学生课程设计作业而开发的项目。该系统旨在帮助大学生学习并掌握Java编程技能,同时锻炼他们的项目设计与开发能力。通过学习基于Java的门诊预约挂号管理系统项目,大学生可以在实践中学习和提升自己的能力,为以后的职业发展打下坚实基础。
130 2
基于Java+Springboot+Vue开发的医院门诊预约挂号系统
|
29天前
|
NoSQL Java Redis
shiro学习四:使用springboot整合shiro,正常的企业级后端开发shiro认证鉴权流程。使用redis做token的过滤。md5做密码的加密。
这篇文章介绍了如何使用Spring Boot整合Apache Shiro框架进行后端开发,包括认证和授权流程,并使用Redis存储Token以及MD5加密用户密码。
24 0
shiro学习四:使用springboot整合shiro,正常的企业级后端开发shiro认证鉴权流程。使用redis做token的过滤。md5做密码的加密。
|
12天前
|
JavaScript 前端开发 Java
SpringBoot_web开发-webjars&静态资源映射规则
https://www.91chuli.com/ 举例:jquery前端框架
12 0
|
1月前
|
前端开发 Java 数据库连接
表白墙/留言墙 —— 中级SpringBoot项目,MyBatis技术栈MySQL数据库开发,练手项目前后端开发(带完整源码) 全方位全步骤手把手教学
本文是一份全面的表白墙/留言墙项目教程,使用SpringBoot + MyBatis技术栈和MySQL数据库开发,涵盖了项目前后端开发、数据库配置、代码实现和运行的详细步骤。
36 0
表白墙/留言墙 —— 中级SpringBoot项目,MyBatis技术栈MySQL数据库开发,练手项目前后端开发(带完整源码) 全方位全步骤手把手教学
|
29天前
|
开发框架 Java API
「SpringBrick快速入门指南」:一款基于Spring Boot的高级插件化开发框架
「SpringBrick快速入门指南」:一款基于Spring Boot的高级插件化开发框架
46 0
|
30天前
|
机器学习/深度学习 移动开发 自然语言处理
基于人工智能技术的智能导诊系统源码,SpringBoot作为后端服务的框架,提供快速开发,自动配置和生产级特性
当身体不适却不知该挂哪个科室时,智能导诊系统应运而生。患者只需选择不适部位和症状,系统即可迅速推荐正确科室,避免排错队浪费时间。该系统基于SpringBoot、Redis、MyBatis Plus等技术架构,支持多渠道接入,具备自然语言理解和多输入方式,确保高效精准的导诊体验。无论是线上医疗平台还是大型医院,智能导诊系统均能有效优化就诊流程。
|
1月前
|
JavaScript 前端开发 数据可视化
【SpringBoot+Vue项目实战开发】2020实时更新。。。。。。
【SpringBoot+Vue项目实战开发】2020实时更新。。。。。。
45 0
下一篇
无影云桌面