电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術(shù)文章
文章詳情頁

Spring Security攔截器引起Java CORS跨域失敗的問題及解決

瀏覽:2日期:2022-08-09 08:21:48

在已設(shè)置CORS的項目中加入Spring Security,導(dǎo)致跨域訪問失敗,一開始以為是設(shè)置錯CORS的問題,后來才發(fā)現(xiàn)是因為Spring Security的攔截沖突引起的。

(一) CORS介紹

CORS是一個W3C標(biāo)準(zhǔn),全稱是”跨域資源共享”(Cross-origin resource sharing)。

它允許瀏覽器向跨源服務(wù)器,發(fā)出XMLHttpRequest請求,從而克服了AJAX只能同源使用的限制。

response響應(yīng)頭響應(yīng)頭字段名稱 作用 Access-Control-Allow-Origin 允許訪問的客戶端的域名 Access-Control-Allow-Credentials 是否允許請求帶有驗證信息,若要獲取客戶端域下的cookie時,需要將其設(shè)置為true。 Access-Control-Allow-Headers 允許服務(wù)端訪問的客戶端請求頭 Access-Control-Allow-Methods 允許訪問的HTTP請求方法 Access-Control-Max-Age 用來指定預(yù)檢請求的有效期(秒),在有效期內(nèi)不在發(fā)送預(yù)檢請求直接請求。

Cors詳細(xì)介紹請看阮一峰的跨域資源共享 CORS 詳解

(二) 服務(wù)端配置CORS(Spring boot)

1、直接寫個filter攔截所有請求在response頭里加上面的字段.

2、繼承WebMvcConfigurerAdapter重寫addCorsMappings

public class CorsConfig extends WebMvcConfigurerAdapter { @Override public void addCorsMappings(CorsRegistry registry) { registry.addMapping('/**') .allowedHeaders('*') .allowedMethods('*') .allowedOrigins('*'); }}

自定義Filter,注冊

@Bean public FilterRegistrationBean corsFilter() { UrlBasedCorsConfigurationSource source = new UrlBasedCorsConfigurationSource(); CorsConfiguration config = new CorsConfiguration(); config.addAllowedOrigin('*'); config.setAllowCredentials(true); config.addAllowedHeader('*'); config.addAllowedMethod('*'); source.registerCorsConfiguration('/**', config); FilterRegistrationBean bean = new FilterRegistrationBean(new CorsFilter(source)); bean.setOrder(0);//配置CorsFilter優(yōu)先級 return bean; }

@CrossOrigin注解

@CrossOrigin(origins = '*',allowCredentials = 'true',allowedHeaders = '*',methods = RequestMethod.GET,maxAge = 3600)(三) 出現(xiàn)的問題

即使配置了響應(yīng)頭字段,還是不能跨域訪問,經(jīng)過反復(fù)測試發(fā)現(xiàn),GET請求可以訪問,PUT請求無法訪問,突然想起:非簡單請求會發(fā)起一個OPTIONS方法的預(yù)檢請求,而我用了Spring Security攔截了所有請求,只開放部分請求,所以需要在Spring Security中設(shè)置不攔截OPTIONS方法的請求。

解決方法

配置Spring Security,設(shè)置不攔截OPTIONS請求

HttpSecurity#authorizeRequests() .antMatchers(HttpMethod.OPTIONS) .permitAll()

配置CorsFilter優(yōu)先級,優(yōu)于Spring Security配置即可!

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持好吧啦網(wǎng)。

標(biāo)簽: Java
相關(guān)文章:
主站蜘蛛池模板: 防爆电机生产厂家,YBK3电动机,YBX3系列防爆电机,YBX4节防爆电机--河南省南洋防爆电机有限公司 | 贝朗斯动力商城(BRCPOWER.COM) - 买叉车蓄电池上贝朗斯商城,价格更超值,品质有保障! | 润东方环保空调,冷风机,厂房车间降温设备-20年深圳环保空调生产厂家 | TwistDx恒温扩增-RAA等温-Jackson抗体-默瑞(上海)生物科技有限公司 | 印刷人才网 印刷、包装、造纸,中国80%的印刷企业人才招聘选印刷人才网! | 机构创新组合设计实验台_液压实验台_气动实训台-戴育教仪厂 | 环讯传媒,永康网络公司,永康网站建设,永康小程序开发制作,永康网站制作,武义网页设计,金华地区网站SEO优化推广 - 永康市环讯电子商务有限公司 | PSI渗透压仪,TPS酸度计,美国CHAI PCR仪,渗透压仪厂家_价格,微生物快速检测仪-华泰和合(北京)商贸有限公司 | 千斤顶,液压千斤顶-力良企业,专业的液压千斤顶制造商,shliliang.com | 世纪豪门官网 世纪豪门集成吊顶加盟电话 世纪豪门售后电话 | 进口便携式天平,外校_十万分之一分析天平,奥豪斯工业台秤,V2000防水秤-重庆珂偌德科技有限公司(www.crdkj.com) | 防火门|抗爆门|超大门|医疗门|隔声门-上海加汇门业生产厂家 | 干培两用箱-细菌恒温培养箱-菲斯福仪器 | 氮化镓芯片-碳化硅二极管 - 华燊泰半导体| 电位器_轻触开关_USB连接器_广东精密龙电子科技有限公司 | 无线讲解器-导游讲解器-自助讲解器-分区讲解系统 品牌生产厂家[鹰米讲解-合肥市徽马信息科技有限公司] | 洛阳网站建设_洛阳网站优化_网站建设平台_洛阳香河网络科技有限公司 | 济宁工业提升门|济宁电动防火门|济宁快速堆积门-济宁市统一电动门有限公司 | 螺旋压榨机-刮泥机-潜水搅拌机-电动泥斗-潜水推流器-南京格林兰环保设备有限公司 | 插针变压器-家用电器变压器-工业空调变压器-CD型电抗器-余姚市中驰电器有限公司 | arch电源_SINPRO_开关电源_模块电源_医疗电源-东佑源 | elisa试剂盒-PCR试剂盒「上海谷研实业有限公司」 | 网站优化公司_SEO优化_北京关键词百度快速排名-智恒博网络 | 翰香原枣子坊加盟费多少钱-正宗枣核糕配方培训利润高飘香 | 日本SMC气缸接头-速度控制阀-日本三菱伺服电机-苏州禾力自动化科技有限公司 | 高楼航空障碍灯厂家哪家好_航空障碍灯厂家_广州北斗星障碍灯有限公司 | 医学动画公司-制作3d医学动画视频-医疗医学演示动画制作-医学三维动画制作公司 | 电销卡 防封电销卡 不封号电销卡 电话销售卡 白名单电销卡 电销系统 外呼系统 | 水冷式工业冷水机组_风冷式工业冷水机_水冷螺杆冷冻机组-深圳市普威机械设备有限公司 | 禹城彩钢厂_钢结构板房_彩钢复合板-禹城泰瑞彩钢复合板加工厂 | 中图网(原中国图书网):网上书店,尾货特色书店,30万种特价书低至2折! | 便携式XPDM露点仪-在线式防爆露点仪-增强型烟气分析仪-约克仪器 冰雕-冰雪世界-大型冰雕展制作公司-赛北冰雕官网 | 真空泵维修保养,普发,阿尔卡特,荏原,卡西亚玛,莱宝,爱德华干式螺杆真空泵维修-东莞比其尔真空机电设备有限公司 | 耐酸碱泵-自吸耐酸碱泵型号「品牌厂家」立式耐酸碱泵价格-昆山国宝过滤机有限公司首页 | 顶空进样器-吹扫捕集仪-热脱附仪-二次热解吸仪-北京华盛谱信仪器 | 泰兴市热钻机械有限公司-热熔钻孔机-数控热熔钻-热熔钻孔攻牙一体机 | 净化车间_洁净厂房_净化公司_净化厂房_无尘室工程_洁净工程装修|改造|施工-深圳净化公司 | 龙门加工中心-数控龙门加工中心厂家价格-山东海特数控机床有限公司_龙门加工中心-数控龙门加工中心厂家价格-山东海特数控机床有限公司 | 六自由度平台_六自由度运动平台_三自由度摇摆台—南京全控科技 | 科威信洗净科技,碳氢清洗机,超声波清洗机,真空碳氢清洗机 | 众品家具网-家具品牌招商_家具代理加盟_家具门户的首选网络媒体。 |