利用Spring Boot框架如何實(shí)現(xiàn)跨域與自定義查詢功能?針對(duì)這個(gè)問(wèn)題,這篇文章詳細(xì)介紹了相對(duì)應(yīng)的分析和解答,希望可以幫助更多想解決這個(gè)問(wèn)題的小伙伴找到更簡(jiǎn)單易行的方法。
10年積累的成都網(wǎng)站設(shè)計(jì)、成都網(wǎng)站制作經(jīng)驗(yàn),可以快速應(yīng)對(duì)客戶對(duì)網(wǎng)站的新想法和需求。提供各種問(wèn)題對(duì)應(yīng)的解決方案。讓選擇我們的客戶得到更好、更有力的網(wǎng)絡(luò)服務(wù)。我雖然不認(rèn)識(shí)你,你也不認(rèn)識(shí)我。但先做網(wǎng)站設(shè)計(jì)后付款的網(wǎng)站建設(shè)流程,更有碑林免費(fèi)網(wǎng)站建設(shè)讓你可以放心的選擇與我們合作。跨域請(qǐng)求
定義:當(dāng)我們從本身站點(diǎn)請(qǐng)求不同域名或端口的服務(wù)所提供的資源時(shí),就會(huì)發(fā)起跨域請(qǐng)求。
例如最常見(jiàn)的我們很多的 css 樣式文件是會(huì)鏈接到某個(gè)公共 CDN 服務(wù)器上,而不是在本身的服務(wù)器上,這其實(shí)就是典型的一個(gè)跨域請(qǐng)求。但瀏覽器由于安全原因限制了在腳本( script )中發(fā)起的跨域 HTTP 請(qǐng)求。也就是說(shuō) XMLHttpRequest 和 Fetch 等是遵循“同源規(guī)則”的,即只能訪問(wèn)自己服務(wù)器的指定端口的資源(同一服務(wù)器不同端口也會(huì)視為跨域)。但這種限制在今天,我們的應(yīng)用需要訪問(wèn)多種外部 API 或 資源的時(shí)候就不能滿足開(kāi)發(fā)者的需求了,因此就產(chǎn)生了若干對(duì)于跨域的解決方案,JSONP 是其中一種,但在今天來(lái)看主流的更徹底的解決方案是 CORS ( Cross-Origin Resource Sharing )。
跨域資源共享 ( CORS )
這種機(jī)制將跨域的訪問(wèn)控制權(quán)交給服務(wù)器,這樣可以保證安全的跨域數(shù)據(jù)傳輸?,F(xiàn)代瀏覽器一般會(huì)將 CORS 的支持封裝在 HTTP API 之中( 比如 XMLHttpRequest 和 Fetch ),這樣可以有效控制使用跨域請(qǐng)求的風(fēng)險(xiǎn),因?yàn)槟憷@不過(guò)去,總得要使用 API 吧。
概括來(lái)說(shuō),這個(gè)機(jī)制是增加一系列的 HTTP 頭來(lái)讓服務(wù)器可以描述哪些源是允許使用瀏覽器來(lái)訪問(wèn)資源的。而且對(duì)于簡(jiǎn)單的請(qǐng)求和復(fù)雜請(qǐng)求,處理機(jī)制是不一樣的。
簡(jiǎn)單請(qǐng)求僅允許三個(gè) HTTP 方法:GET,POST 以及 HEAD,另外只能支持若干 header 參數(shù):Accept , Accept-Language , Content-Language , Content-Type (值只能是 application/x-www-form-urlencoded、multipart/form-data 和 text/plain), DPR , Downlink , Save-Data , Viewport-Width 和 Width。
對(duì)于簡(jiǎn)單請(qǐng)求來(lái)說(shuō),比如下面這樣一個(gè)簡(jiǎn)單的GET請(qǐng)求:從 http://me.domain 發(fā)起到 http://another.domain/data/blablabla 的資源請(qǐng)求
GET /data/blablabla/ HTTP/1.1 // 請(qǐng)求的域名 Host: another.domain ...//省略其它部分,重點(diǎn)是下面這句,說(shuō)明了發(fā)起請(qǐng)求者的來(lái)源 Origin: http://me.domain