安庆大理运城常德铜陵江西
投稿投诉
江西南阳
嘉兴昆明
铜陵滨州
广东西昌
常德梅州
兰州阳江
运城金华
广西萍乡
大理重庆
诸暨泉州
安庆南充
武汉辽宁

SpringBoot进阶SpringBoot中如何解决跨域问

4月8日 红朱砂投稿
  什么是跨域问题
  浏览器出于安全考虑,会限制跨域访问,就是不允许跨域请求资源,要求协议,IP和端口必须都相同,其中有一个不同就会产生跨域问题,这就是同源策略。
  简单的说A应用只能访问A应用对应的后台返回的数据,B应用只能访问B应用后台的数据,如果A应用通过Ajax请求了B应用对应的后台数据的时候就会出现跨域的问题。但是在实际开发中,这种调用方式又是被大家广泛使用的。非同源限制
  什么是非同源限制?浏览器为了安全限制了一些操作,限制了一些请求是无法访问非同源的操作的。无法读取非同源网页的Cookie、LocalStorage和IndexedDB无法获取到非同源网页的DOM无法向非同源地址发送Ajax请求操作CORS技术
  为了解决上述问题,W3C提出了跨院资源共享方案,也就是CORS技术(CrossOriginResourceSharing)
  CORS可以在不破坏现有规则的情况下,通过后端服务器实现CORS接口,从而实现跨域通信。CORS请求分为两类:简单请求和非简单请求,分别对跨域通信提供了支持操作。什么是简单请求
  在CORS技术出现之前,在HTTP请求头中不能包含任何的自定义字段,而且HTTP请求信息也不能操作如下的一些AcceptAcceptLanguageContentLanguageLastEventIDContentType(applicationxwwwformurlencoded、multipartformdata、textplain)
  根据对简单请求的的分析,CORS的策略是在请求时在请求头中增加一个Origin字段,服务器收到请求后,根据该字段判断是否允许该请求访问。如果允许,就在HTTP请求头信息中添加AccessControlAllowOrigin字段,并且返回正确的字段如果不允许,就不加入该字段
  处理AccessControlAllowOrigin字段,还有其他的字段可以描述CORS返回结果AccessControlAllowCredentials:可选,用户是否可以发送、处理cookie。AccessControlExposeHeaders:可选,可以让用户拿到的字段,有即可字段无论设置与否都可以获取到,包括CacheControl、ContentLanguage、ContentType、Expires、LastModified、Pragma。什么是非简单请求
  对于非简单请求的跨源请求,浏览器会在真实请求发出前增加一次OPTION请求,称为预检请求。在预检请求将真实请求的信息,包括请求方法、自定义头字段、源信息添加到HTTP头信息字段中,询问服务器是否允许这样的操作。
  例如在一个GET请求中,与CORS相关的字段有:请求使用的HTTP方法AccessControlRequestMethod请求中包含的自定义头字段AccessControlRequestHeaders
  服务器收到请求时,需要对Origin、AccessControlRequestMethod、AccessControlRequestHeaders进行验证,验证通过后,会在返回HTTP头信息中添加如下的的内容AccessControlAllowOrigin:AccessControlAllowMethods:真实请求允许的方法AccessControlAllowHeaders:服务器允许使用的字段AccessControlAllowCredentials:是否允许用户发送、处理CookieAccessControlMaxAge:预检请求的有效期,单位为秒,有效期内,不会重复发送预检请求在SpringBoot中如何实现跨域
  对于CORS的跨域请求,主流的解决方案有如下几种添加跨域配置类重写WebMvcConfigurer使用CrossOrigin注解手动设置响应头自定义过滤器
  对于前后端分离的项目还可以通过配置Nginx的方式实现跨域操作
  CorFilterWebMvConfigurerCrossOrigin需要SpringMVC4。2以上版本才支持,对应springBoot1。3版本以上上面前两种方式属于全局CORS配置,后两种属于局部CORS配置。如果使用了局部跨域是会覆盖全局跨域的规则
  所以可以通过CrossOrigin注解来进行细粒度更高的跨域资源控制。其实无论哪种方案,最终目的都是修改响应头,向响应头中添加浏览器所要求的数据,进而实现跨域添加跨域配置类
  新建一个全局的跨域配置文件,然后添加对应的Cors跨域信息,包括放行原始域、发送Cookie等操作,代码如下。ConfigurationpublicclassGlobalCorsConfig{BeanpublicCorsFiltercorsFilter(){1。添加CORS配置信息CorsConfigurationconfignewCorsConfiguration();放行哪些原始域config。addAllowedOrigin();是否发送Cookieconfig。setAllowCredentials(true);放行哪些请求方式config。addAllowedMethod();放行哪些原始请求头部信息config。addAllowedHeader();暴露哪些头部信息config。addExposedHeader();2。添加映射路径UrlBasedCorsConfigurationSourcecorsConfigurationSourcenewUrlBasedCorsConfigurationSource();corsConfigurationSource。registerCorsConfiguration(,config);3。返回新的CorsFilterreturnnewCorsFilter(corsConfigurationSource);}}重写WebMvcConfigurer
  重新实现WebMvcConfigurerConfigurationpublicclassCorsConfigimplementsWebMvcConfigurer{OverridepublicvoidaddCorsMappings(CorsRegistryregistry){registry。addMapping()允许跨域访问。allowedOrigins()允许跨域访问的源。allowedMethods(POST,GET,PUT,DELETE,OPTIONS)允许请求的方式。maxAge(168000)预检间隔时间。allowCredentials(true);是否发送Cookie}}注解CrossOrigin
  注意使用这个注解只是对局部接口实现了跨域操作,代码如下RestControllerCrossOrigin(origins)publicclassHelloController{RequestMapping(hello)publicStringhello(){}}
  如果是在方法上使用这个注解则表示只允许这个方法进行跨域访问RequestMapping(hello)CrossOrigin(origins)CrossOrigin(valuehttp:localhost:8081)指定具体ip允许跨域publicStringhello(){}手动设置过滤头RestControllerRequestMapping(api)publicclassApiController{GetMapping(getList)publicStringgetList(HttpServletResponseresponse){response。addHeader(AccessAllowControlOrigin,);returnOK;}}
  自定义过滤器ComponentpublicclassCorsFilterimplementsFilter{Overridepublicvoidinit(FilterConfigfilterConfig)throwsServletException{}OverridepublicvoiddoFilter(ServletRequestservletRequest,ServletResponseservletResponse,FilterChainfilterChain)throwsIOException,ServletException{HttpServletResponseresponse(HttpServletResponse)servletRresponse。setHeader(AccessControlAllowOrigin,);response。setHeader(AccessControlAllowMethods,POST,GET,OPTIONS,DELETE);response。setHeader(AccessControlMaxAge,3600);response。setHeader(AccessControlAllowHeaders,xrequestedwith,contenttype);filterChain。doFilter(servletRequest,servletResponse);}Overridepublicvoiddestroy(){}}
  当然自定的话就会涉及到这个配置如何去使用的问题。在之前的文章中我们有讲过如何使用自定义的拦截器。这里我们就在过多说明,有兴趣的读者可以查看之前的文章。Nginx服务器反向代理
  通过反向代理监听同样的端口、同样的域名的不同访问地址。例如可以在Nginx配置中进行如下的配置server{listen80;servernameabc。charsetkoi8r;accessloglogshost。access。locationclient{访问客户端路径proxypasshttp:localhost:81;}locationapis{访问服务器路径rewriteapis(。)1proxypasshttp:localhost:82;}}
  可以将不同路径的请求分别转发到客户端和服务器端,利用Nginx反向代理技术来实现跨域操作。总结
  当然对于跨域问题还有很多前端实现方式。这里我们主要讲关于后端的实现的方式,对于前端实现方式有兴趣的读者可以自己了解。东西不多,都是干活,希望大家多多关注。
投诉 评论 转载

女生穿超短裙出门是什么体验?01hr看我的腿这么长这么白瞬间感觉自己是全世界的小公举02hr夏天雷阵雨吹起大风时双手拼死按住裙子发丝在风里肆意起舞也管不了那么多了……少装了!圈内好友的这波捅刀,打得小s脸好疼在蓝正龙、周渝民、汪小菲等人,先后折戟在大s手上,尤其是汪小菲简直是典型的赔了夫人又折金之后,许雅钧这个圈外人,反而大出风头。原因无他,s家几个女人都不好惹,……外国导师问我怎么用英文键盘打出中文?原来中文打字经历了这么多有网友在网上分享自己在国外留学的趣事,提到了中文打字的事情。某天早上,网友正在实验室里用word文档整理实验步骤。由于打的全都是中文,以至于网友的意大利导师路过网友电脑的……不确定时代,华都酒业的确定性几何?摘要:11月5日,承天门文化体验中心开业,与茅台国际大酒店隔美酒河相望,面积近一千平米;也在这一天,行业首发的北京、习水、茅台三地文化酱酒之旅启航。从品牌形象出现在成都核……ChatGPT真的很惊艳ChatGPT最近一经推出,就引起很大的轰动,朋友圈到处转发各种使用体验,甚至有人把它做成一门生意:卖账号。有人说它最大的意义可能是颠覆传统的搜索引擎,谷歌百度危矣。像我这种对……2022。11。23最新早安图片祝福丨周三温馨问候丨朋友圈早清晨的问候,就是我们彼此的相约。相约健康,相约平安;相约幸福,相约快乐!早安!冷风呼呼吹,我把祝福来送上:天寒地冻易受凉,多穿衣服要保暖;早出晚归温差大,增添衣服要恰当;……日本女团头戴大熊猫开心领奖伊藤美诚传达两国友好情谊日本女团头戴大熊猫开心领奖。国际乒联供图中新网成都10月9日电(记者贺劭清)其实这个大熊猫配饰是早田希娜和她的教练在酒店发现的,那是一个画自画像的活动,我们六个人都画了自……遮羞布被撕碎,消费者丝毫不在乎手机是否支持5G,5G该往何处近日市调机构Omdia公布的一份调查数据指出全球大多数手机用户都不在乎手机是否支持5G,5G和4G的体验几乎没有差别,所以消费者买手机已不在乎手机是否支持5G,反而更看重手机的……我向往着重游川西,重温青丝白头的感动梦回2018那年的秋天,我站在四姑娘山上与大自然相拥,鼻尖似乎触碰到了那冷冽的寒风,正贪婪的深吸两口,陡然发现,现在已是2022年的秋天!虽然旅途中的点滴还历历在目,可我……男女混住的越南青年旅馆,保护隐私就靠一块布,为啥这么受欢迎?你见过男女混住的旅馆吗?在越南,有很多这样的青年旅馆,因为价格便宜,所以非常受欢迎。住一晚只要15到20元人民币,对于又穷又想浪的穷游者来说,确实是不错的选择。不过……科尔库里被打到脑袋是必须响哨的他是库里你不能漏吹这种球直播吧12月14日讯勇士今日客战111128不敌雄鹿。赛后,科尔谈到了自己在比赛中吃到的技犯,他说:在技犯之前,我就已经对一些吹罚不满意了,我认为普尔的一次突破应该是米德……SpringBoot进阶SpringBoot中如何解决跨域问什么是跨域问题浏览器出于安全考虑,会限制跨域访问,就是不允许跨域请求资源,要求协议,IP和端口必须都相同,其中有一个不同就会产生跨域问题,这就是同源策略。简单的说A……
霍华德印度旅行人气超高!不少球迷索要签名合照,魔兽灵魂重生食品安全对肿瘤患者的影响如何?今晚无眠2023年普通人在经济方面将面临什么又该做好怎样的准备卧槽,这片有毒!人兽恋竟然可以这么甜钟丽缇一家四口跳爱你,穿连体裤成大号王心凌,俩女儿颜值高将自己的眼界投向远方,就能收获更多的爱与善良吉利全资控股魅族科技魅族创始人黄章退出,手机门店也要卖车苹果官网标错价格,精神小伙一夜怒薅12万,结局你猜到了吗?国药控股全渠道推广格列卫,业内人士或成为药物营销推广的新风向吹响胜利号角的利器!美商海盗船外设全家桶体验!选对这三点,能让你少奋斗十年阴囊潮湿的原因是什么?一封离职的来信渐渐变老的70后,学会对以下五种人薄情,避免晚景凄凉阿富汗碧玺(巴西的碧玺有什么特点)我长大了纸质玩具的安全隐患八字中偏印与坐支的关系时间管理:一张A4纸,掌控工作与生活十二星座代表的包包(最稀有的星座)如何查银行卡号(如何查看银行卡号全号)醉梦在这思恋的海洋中,只想长醉不醒,在这开满勿忘我的田野上。大自然的科普知识台风的风眼中没有风的原因

友情链接:中准网聚热点快百科快传网快生活快软网快好知文好找七猫云易事利