成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

SpringBoot 項目處理跨域的四種技巧

開發(fā) 前端
CORS?是一個?W3C?標準,全稱是"跨域資源共享"(Cross-origin ?resource ?sharing), 它需要瀏覽器和服務器同時支持他,允許瀏覽器向跨源服務器發(fā)送XMLHttpRequest請求,從而克服 AJAX 只能同源使用的限制。

上周幫一家公司優(yōu)化代碼時,順手把跨域的問題解決了, 這篇文章,我們聊聊 SpringBoot 項目處理跨域的四種技巧 。

圖片圖片

一、什么是跨域

我們先看下一個典型的網(wǎng)站的地址:

圖片圖片

同源是指:協(xié)議、域名、端口號完全相同。

下表給出了與 URL http://www.training.com/dir/page.html 的源進行對比的示例 :

圖片圖片

當用戶通過瀏覽器訪問應用(http://admin.training.com)時,調用接口的域名非同源域名(http://api.training.com),這是顯而易見的跨域場景。

二、理解 CORS

CORS 是一個 W3C 標準,全稱是"跨域資源共享"(Cross-origin  resource  sharing), 它需要瀏覽器和服務器同時支持他,允許瀏覽器向跨源服務器發(fā)送XMLHttpRequest請求,從而克服 AJAX 只能同源使用的限制。

跨域資源共享標準新增了一組 HTTP 首部字段,允許服務器聲明哪些源站通過瀏覽器有權限訪問哪些資源。

規(guī)范要求,對那些可能對服務器數(shù)據(jù)產生副作用的 HTTP 請求方法(特別是 GET 以外的 HTTP 請求,或者搭配某些 MIME 類型的 POST 請求),瀏覽器必須首先使用 OPTIONS 方法發(fā)起一個預檢請求(preflight request),從而獲知服務端是否允許該跨域請求。

服務器確認允許之后,才發(fā)起實際的 HTTP 請求。在預檢請求的返回中,服務器端也可以通知客戶端,是否需要攜帶身份憑證(包括 Cookies 和 HTTP 認證相關數(shù)據(jù))。

圖片圖片

1.簡單請求

簡單請求模式,瀏覽器直接發(fā)送跨域請求,并在請求頭中攜帶 Origin 的頭,表明這是一個跨域的請求。 服務器端接到請求后,會根據(jù)自己的跨域規(guī)則,通過 Access-Control-Allow-Origin 和 Access-Control-Allow-Methods 響應頭,來返回驗證結果。

圖片圖片

2.預檢請求

瀏覽器在發(fā)現(xiàn)頁面發(fā)出的請求非簡單請求,并不會立即執(zhí)行對應的請求代碼,而是會觸發(fā)預先請求模式。預先請求模式會先發(fā)送preflight request(預先驗證請求),preflight request是一個 OPTION 請求,用于詢問要被跨域訪問的服務器,是否允許當前域名下的頁面發(fā)送跨域的請求。在得到服務器的跨域授權后才能發(fā)送真正的 HTTP 請求。

圖片圖片

三、Nginx 配置

圖片圖片

我們不用配置 SpringBoot 項目,在反向代理層 Nginx 直接配置 CORS ,典型配置如下圖:

圖片圖片

四、配置類實現(xiàn) addCorsMapping 接口

SpringBoot 中新增一個配置類 CorsConfig.java,繼承 WebMvcConfigurerAdapter 或者實現(xiàn)WebMvcConfigurer 接口,項目啟動后,會自動讀取配置。

圖片圖片

五、CorsFilter 過濾器模式

下圖是 SpringMvc 模式里,過濾器,攔截器,控制器的執(zhí)行順序。

圖片圖片

CorsFilter 過濾器模式的優(yōu)點是:優(yōu)先級高,可以規(guī)避代碼中業(yè)務攔截器異常導致 adCorsMappings 方法失效的問題。

我們需要定義一個 corsFilter 方法,@Bean 注解表示此方法返回一個Spring Bean,該 Bean 將由Spring 容器管理。

corsFilter() 方法定義了一個 FilterRegistrationBean,這個 bean 是用來注冊 CorsFilter 的,后者用于處理 CORS 請求。

圖片圖片

六、網(wǎng)關模式

在微服務架構體系中,網(wǎng)關是非常核心的組件。 API 網(wǎng)關可以做鑒權,限流,灰度等,同時可以配置 CORS 。內部服務端不用特別關注跨域這個問題。

圖片圖片

因此假如是 SpringCloud 體系,我們只需要配置 SpringCloud gateway 的跨域即可。

責任編輯:武曉燕 來源: 勇哥Java實戰(zhàn)
相關推薦

2025-01-15 12:43:23

2024-05-22 19:10:18

跨域Web開發(fā)

2017-02-28 14:28:37

數(shù)據(jù)跨庫分頁架構

2010-07-28 22:35:25

ADSL掉線

2025-06-12 03:55:00

項目處理異常代碼

2020-08-10 00:30:55

備份密碼iPhone移動安全

2022-10-09 18:16:01

Flowable設置ReceiveTas

2024-12-02 14:30:20

2017-09-01 11:59:59

Android

2021-02-21 21:20:24

SpringBoot異步網(wǎng)絡

2011-11-24 16:34:39

Java

2019-10-24 07:42:28

Java引用GC

2017-07-06 15:40:19

DevOps核心能力

2012-09-11 09:55:26

編程HTML5編程能力

2011-03-16 09:05:53

NATiptables

2025-01-15 08:42:41

2023-08-10 11:39:54

RabbitMQSpring交換機

2021-10-24 08:37:18

網(wǎng)絡監(jiān)控網(wǎng)絡架構網(wǎng)絡

2020-06-12 08:28:29

JavaScript開發(fā)技術

2020-11-10 10:08:41

Kubernetes容器開發(fā)
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 91色在线| 国产精品久久久久久久久久久免费看 | 啪啪毛片 | 日韩精品色网 | 99re在线视频| 久久国产精品视频 | 免费观看av| 中文字幕精品一区久久久久 | 刘亦菲国产毛片bd | 在线观看免费av网站 | 久久五月婷 | 在线观看第一页 | 99亚洲| 91精品国产91久久久久久三级 | 欧美综合久久 | 伊人焦久影院 | 成人免费网站在线 | 国产成人久久精品 | 91丨九色丨国产在线 | 国产精品777一区二区 | 综合色播| www.一级毛片 | 夜夜爽99久久国产综合精品女不卡 | 成人国产a| 国产区在线观看 | 黄色一级免费 | 亚洲国产精品一区二区第一页 | 久久蜜桃av一区二区天堂 | 国产欧美性成人精品午夜 | 视频一区二区中文字幕 | 久久久九九 | 天天综合久久 | 日韩在线小视频 | 久久久蜜桃一区二区人 | 国产精品视频999 | 日本特黄a级高清免费大片 特黄色一级毛片 | 日韩欧美在线观看视频 | 黄免费观看视频 | 天天干夜夜拍 | 黄色一级大片视频 | 天天射视频 |