跨域资源访问:CORS
admin
2024-02-12 23:46:13
0

跨域资源访问:CORS

介绍:

CORS(Cross-origin resource sharing)是由W3C定制的一种跨域资源共享技术,其目的就是为例解决前端的跨域请求。在javaEE开发中,最常见的前端跨域请求解决方案时JSONP,但是JSONP只支持GET请求;

什么是JavaEE请求:

它的原理是借助script标签不受浏览器同源策略限制,允许跨域请求资源,因此可以通过script标签的src属性,进行跨域访问。

代码如下:

// 1. 前端定义一个 回调函数 handleResponse 用来接收后端返回的数据
function handleResponse(data) {console.log(data);
};// 2. 动态创建一个 script 标签,并且告诉后端回调函数名叫 handleResponse
var body = document.getElementsByTagName('body')[0];
var script = document.gerElement('script');
script.src = 'http://www.laixiangran.cn/json?callback=handleResponse';
body.appendChild(script);// 3. 通过 script.src 请求 `http://www.laixiangran.cn/json?callback=handleResponse`,
// 4. 后端能够识别这样的 URL 格式并处理该请求,然后返回 handleResponse({"name": "laixiangran"}) 给浏览器
// 5. 浏览器在接收到 handleResponse({"name": "laixiangran"}) 之后立即执行 ,也就是执行 handleResponse 方法,获得后端返回的数据,这样就完成一次跨域请求了。

CORS 支持多种 HTTP 请求,它其实就是定义了一套跨域资源请求时,浏览器与服务器之间的交互方式。基本的原理就是通过自定义的 HTTP 请求头来传递信息,进行验证。

CORS的用法:

方法一:使用**@CrossOrigin**

该注解可用于方法和类上,注解在方法上,表示对该方法的请求进行 CORS 校验,注解在类上(即Controller上),表示该类内的方法都遵循该 CORS 校验。如下所示:

@Slf4j
@RestController
@RequestMapping("cors")
@CrossOrigin(value = "http://127.0.0.1:5500", maxAge = 1800,allowedHeaders = "*")
public class CorsController {@PostMapping("/")public String add(@RequestParam("name") String name,@RequestHeader("Origin") String origin) {log.info("Request Header ==> Origin: " + origin);return "add successfully: " + name;}@DeleteMapping("/{id}")public String delete(@PathVariable("id") Long id) {return String.valueOf(id) + " deleted!";}
}

@CrossOrigin注解可选参数如下:

方法作用
value表示支持的域,即Access-Control-Allow-Origin的值
origins表示支持的域数组
methods表示支持的 CORS 请求方法,即Access-Control-Allow-Methods的值。 其默认值与绑定的控制器方法一致
maxAge表示探测请求缓存时间(单位:秒),即Access-Control-Max-Age的值。 其默认值为1800,也即 30 分钟
allowedHeaders表示允许的请求头,即Access-Control-Allow-Headers的值 默认情况下,支持所有请求头
exposedHeaders表示下发其他响应头字段给浏览器,即Access-Control-Expose-Headers的值。 默认不下发暴露字段
allowCredentials表示是否支持浏览器发送认证信息(比如 Cookie),即Access-Control-Allow-Credentials的值。 默认不支持接收认证信息

方式二:配置类

增加一个配置类,CrossOriginConfig.java。继承WebMvcConfigurerAdapter或者实现WebMvcConfigurer接口,其他都不用管,项目启动时,会自动读取配置。

@Configuration
public class WebMvcConfig implements WebMvcConfigurer {@Overridepublic void addCorsMappings(CorsRegistry registry) {registry.addMapping("/**")     //设置允许跨域的路径.allowedOrigins("*").allowedMethods("*").allowedHeaders("*").maxAge(1800).allowCredentials(true);}
}

只需创建一个配置类实现接口WebMvcConfigurer,然后覆写方法addCorsMappings即可。
addCorsMappings方法中,registry.addMapping用于设置可以进行跨域请求的路径,比如/cors/**表示路径/cors/下的所有路由都支持 CORS 请求。其他的设置与注解@CrossOrigin一样,无需介绍。

方法三:采用过滤器(filter)的方式

 @Component
public class CORSFilter implements Filter {@Overridepublic void doFilter(ServletRequest request, ServletResponse response, FilterChain chain)throws IOException, ServletException {HttpServletResponse res = (HttpServletResponse) response;res.addHeader("Access-Control-Allow-Credentials", "true");res.addHeader("Access-Control-Allow-Origin", "*");res.addHeader("Access-Control-Allow-Methods", "GET, POST, DELETE, PUT");res.addHeader("Access-Control-Allow-Headers", "Content-Type,X-CAF-Authorization-Token,sessionToken,X-TOKEN");if (((HttpServletRequest) request).getMethod().equals("OPTIONS")) {response.getWriter().println("ok");return;}chain.doFilter(request, response);}@Overridepublic void destroy() {}@Overridepublic void init(FilterConfig filterConfig) throws ServletException {}
}

Spring Security 配置跨域:如果项目中使用了 Spring Security 框架,那么也可以直接配置 Spring Security 支持跨域即可:

@Configuration
public class SecurityConfiguration extends WebSecurityConfigurerAdapter {@Overrideprotected void configure(HttpSecurity http) throws Exception {// 允许跨域资源请求// by default uses a Bean by the name of corsConfigurationSourcehttp.cors(Customizer.withDefaults());}@BeanCorsConfigurationSource corsConfigurationSource() {CorsConfiguration configuration = new CorsConfiguration();configuration.setAllowedOrigins(Arrays.asList("*"));configuration.setAllowedMethods(Arrays.asList("GET","POST","OPTIONS"));UrlBasedCorsConfigurationSource source = new UrlBasedCorsConfigurationSource();// 所有 url 都使用 configuration 定制的跨域规则source.registerCorsConfiguration("/**", configuration);return source;}
}

相关内容

热门资讯

去陕西5日游最佳路线,西安5天... 西安拥有众多闻名遐迩的旅游景点,每一处都承载着丰富的历史信息和独特的文化价值。兵马俑,被誉为“世界第...
洪荒时所有先天宝物名称 洪荒时所有先天宝物名称河图洛书,太极图,盘古幡,东皇钟,炼妖壶,定海珠,十二品金莲,七宝妙树,
长子鼓书钉缸台词? 长子鼓书钉缸台词?孝心可嘉 希望能帮到你钉缸是借黎城民间生活“钉缸”,经艺人编演口传的一曲风趣小戏。...
英文歌有哪些比较舒缓好听的? 英文歌有哪些比较舒缓好听的?以前我在一家SPA馆听到有个外国女的唱的英文歌很好听,曲调比较舒缓的,在...
我只是一棵小草,等待属于我唯一... 我只是一棵小草,等待属于我唯一的阳光 英文怎么说?为你提供正确译文:I am just a litt...
相遇交友平台是否停播 相遇交友平台是否停播相遇平台没有停播。相遇平台正在进行正常的系统维护。系统维护结束之后,用户就可以正...
精神涣散 健忘 思想无法集中 精神涣散 健忘 思想无法集中你可能是休息不好引起的,或者是有严重的心结没有解开,需要放松心情,或者是...
关于环保的小故事! 关于环保的小故事!小时候,听奶奶讲过这样一个故事:从前,有座山庄,那里森林葱郁,河水清澈,鸟语花香,...
雪梨戚风蛋糕的常见做法? 雪梨戚风蛋糕的常见做法?牛奶,油,倒入大碗,搅拌均匀。加入一半板栗粉末和蜂蜜,搅拌均匀。倒入剩下的栗...
怎样接受他的吻? 怎样接受他的吻?我也曾经和你一样,当时有点害怕。没事的,感觉很好的感觉就像触电一样,头脑中一片空白,...
西格玛男人啥意思 西格玛男人啥意思“西格玛男人”是一个网络流行语,指的是那些在某一领域非常擅长、精通,并能够以高标准、...
有一首香港老歌,是男女对唱的。... 有一首香港老歌,是男女对唱的。好像是哪部香港古装电影上的合唱: 張學友和湯寶如 歌名: 相思風雨中 ...
谁知道《让快乐飞翔》这首儿童歌... 谁知道《让快乐飞翔》这首儿童歌曲的谱?能不能传一份给我?天上一个大太阳 穿着红衣裳藏着星星 藏着月亮...
贝多芬 《孩子的梦》 背景介绍... 贝多芬 《孩子的梦》 背景介绍 贝多芬 《孩子的梦》 背景介绍ikjldsajlkjasdjiasd...
明朝奇案:妇人艳妆戴孝祭奠丈夫... 明朝奇案:妇人艳妆戴孝祭奠丈夫,被大人识破,背后有什么冤案呢?因为她的丈夫就是被妇人给毒死的,然后我...
著名的书法碑帖有哪些 著名的书法碑帖有哪些王羲之《兰亭集序》被尊为天下第一行书;颜真卿《祭侄文稿》被尊为天下第二行书;楷书...
搜集生活中常见的错别字,广告用... 搜集生活中常见的错别字,广告用语中用错的成语,并探究其原因仃(停)车场 原因:很多大城市的停车场都这...
国际学校11年级是国内几年级 国际学校11年级是国内几年级国际学校11年级(G2)相当于国内高二年级11年级相当于国内高中二年级。...
北京天坛公园有什么特点 北京天坛公园有什么特点回答的很明确,很满意。
一个人内心可以有多苦? 一个人内心可以有多苦?可以苦到用任芹御何 语言 行为 都无法表达 承受的越多 心里就越苦 不愿意跟...