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

跨域請求產(chǎn)生錯誤的原因及處理方法

開發(fā) 前端
如果你在開發(fā)網(wǎng)站時曾經(jīng)嘗試通過框架或是瀏覽器的 fetch、XHR 請求過外部 API 的話,那么一定遇到過跨域請求,還有那個觸目驚心的 CORS 錯誤信息;今天咱們來討論跨域問題的原因以及解決方法。

如果你在開發(fā)網(wǎng)站時曾經(jīng)嘗試通過框架或是瀏覽器的 fetch、XHR 請求過外部 API 的話,那么一定遇到過跨域請求,還有那個觸目驚心的 CORS 錯誤信息;今天咱們來討論跨域問題的原因以及解決方法。

[[358796]]

跨域請求

如果你沒有沒有遇過,可以試著在瀏覽器的 console 頁輸入下面的代碼:

  1. const xhr = new XMLHttpRequest() 
  2. xhr.onreadystatechange = () => { 
  3.   if (xhr.readyState === 4) { 
  4.     console.log(xhr.status === 200 ? xhr.responseText : 'error') 
  5.   } 
  6. xhr.open('GET', 'https://google.com') 
  7. xhr.send() 

這段代碼通過調(diào)用瀏覽器的 XMLHttpRequest 對 Google 發(fā)出請求,而得到的結(jié)果如圖所示:

這就是跨域請求問題,當(dāng)通過 JavaScript 對不同的來源發(fā)送請求時,這個請求的響應(yīng)就會被瀏覽器攔截,不交給 JavaScript 處理。這里的“不同來源”指的是目標資源與當(dāng)前網(wǎng)頁的域(domain)、通訊協(xié)議(protocol)或網(wǎng)絡(luò)端口(port)只要有任一項不同,就算是不同來源。例如下面這幾個例子:

  1. 假設(shè)當(dāng)前用戶在:https://example.com : 
  2. [✅] https://example.com/test -> 同域 
  3. [❌] https://m.example.com -> 不同域 
  4. [❌] https://example.com:3000 -> 端口不同 
  5. [❌] http://example.com -> 通訊協(xié)議不同 

理解什么是跨域了,那為什么瀏覽器要把跨域請求資源攔截掉呢?

其實這是考慮到用戶的信息安全。

假設(shè)小黑是一個惡意開發(fā)者,他編寫的網(wǎng)站會嘗試通過 XHR 打向百度、微博等目標網(wǎng)站;如果使用者原先就有目標網(wǎng)站的登錄狀態(tài),小黑便能窺探他的隱私,得到不該取得的數(shù)據(jù)。再想想看,如果目標網(wǎng)站換成 Email、銀行、電商,如果沒有瀏覽器限制跨域請求的保護,惡意開發(fā)者便能為所欲為。

注意:跨域請求雖然會被瀏覽器攔截下來,但攔截的是響應(yīng)(Response)而不是請求(Request)。

解決方案

關(guān)于跨域請求的解決方案有很多,例如 JSONP,也就是通過 HTML 中沒有跨域限制的標簽如 img、script 等,再通過指定回調(diào)函數(shù),將響應(yīng)的內(nèi)容介接回 JavaScript 中;或是通過 iframe,繞過跨域保護獲取目標資源等。下面僅說明兩種常見也相對正規(guī)的解決方式。

1. CORS

最標準、正確的解決方法是通過 W3C 規(guī)范 的“ 跨域資源共享(Cross-Origin Resource Sharing ,CORS)”,通過服務(wù)器在 HTTP 頭中的設(shè)置,可以使瀏覽器能夠獲取不同來源的資源。

CORS 規(guī)范中,清楚定義了跨域存取控制的運作方式。

首先服務(wù)器端需要在響應(yīng)頭中加上如 Access-Control-Allow-Origin、Access-Control-Request-Method、Access-Control-Request-Headers 等設(shè)定,來限制服務(wù)器所能接受的來源、請求的方法、可攜帶的頭等等。

當(dāng)瀏覽器發(fā)送資源請求時,如果是簡單請求便會直接送出請求;若不符合前述條件,則會通過預(yù)檢(Preflighted)請求先敲敲門,確認是否可以通過服務(wù)器的限制,然后才會發(fā)送正式的請求。

CORS 除了上述內(nèi)容外,也有關(guān)于 Cookies 的傳送方式,如何允許跨域?qū)懭?Cookies 等內(nèi)容。

2. 代理服務(wù)器

由于 CORS 的頭設(shè)置是在服務(wù)器端,如果服務(wù)器是自己的,那么可以輕易的調(diào)整服務(wù)器設(shè)置,讓前端能取得必要的資源;但如果你請求的是外部 API,總不能每次遇到 CORS 錯誤,就要求別人去修改頭設(shè)置吧。

簡單暴力的方法就是通過代理服務(wù)器幫我們獲取資源;由于跨域保護的限制是瀏覽器的規(guī)范,只要不通過瀏覽器發(fā)送請求,自然也就不會有限制。

常見的作法是通過 nginx 做簡單的反向代理;例如在自己的開發(fā)環(huán)境,前后端分離的架構(gòu),前后端服務(wù)分別啟動在 3000 和 5000 端口,則可以用這樣的配置:

  1. server{ 
  2.   listen 3000; 
  3.   server_name localhost; 
  4.   location ^~ /api { 
  5.   proxy_pass http://localhost:5000; 
  6.   } 

當(dāng)前端需要發(fā)送 API 請求時,可以直接請求 localhost:3000/api/...,這個請求會被 nginx 攔截,并轉(zhuǎn)發(fā)給后端所在的 localhost:5000,這樣就能簡單的繞過跨域保護了。

總結(jié)

跨域是前端常見的需求,CORS 的錯誤信息也是我們很容易被卡住的地方;其實只要清楚 CORS 規(guī)范中的 HTTP 頭設(shè)置,并在服務(wù)器端做對應(yīng)的調(diào)整,就可以順利的完成跨域請求。

 

責(zé)任編輯:趙寧寧 來源: 前端先鋒
相關(guān)推薦

2024-05-31 12:50:49

C++編程NaN

2017-05-25 09:45:35

2011-11-07 11:15:31

2024-08-23 09:00:18

開發(fā)跨域請求

2010-06-01 15:58:14

SVN錯誤

2024-08-28 08:45:22

2011-06-22 18:50:03

網(wǎng)站快照

2020-04-02 10:08:52

SSD硬盤存儲硬盤故障

2024-05-20 09:28:44

Spring客戶端瀏覽器

2021-04-27 15:20:41

人工智能機器學(xué)習(xí)技術(shù)

2011-07-05 10:48:41

javascript

2022-04-29 09:11:14

CORS瀏覽器

2020-08-13 07:04:45

跨域CORS瀏覽器

2021-06-10 18:11:02

Cors跨域Web開發(fā)Cors

2023-03-16 23:54:19

服務(wù)器vmtoolsd組件

2010-09-08 15:28:50

SQL Server復(fù)制

2018-09-18 09:02:18

機房故障處理

2018-12-12 15:50:13

2022-04-01 12:38:32

cookie代碼面試

2025-01-06 08:33:10

點贊
收藏

51CTO技術(shù)棧公眾號

主站蜘蛛池模板: 亚洲狠狠爱 | 亚洲精品在线看 | 精品产国自在拍 | 国产精品无码专区在线观看 | 日日摸日日添日日躁av | 国产成人一区在线 | 狠狠婷婷综合久久久久久妖精 | 91久久| 久久亚洲欧美日韩精品专区 | 欧美国产一区二区 | 日韩在线不卡视频 | 视频一区在线 | 在线视频 亚洲 | 欧美视频免费在线 | 久久人体 | 精品真实国产乱文在线 | 欧美日韩亚洲一区 | 欧美成人自拍视频 | 91一区| 亚洲一区二区三区免费视频 | 欧美一区视频在线 | 91在线视频免费观看 | 国产香蕉视频在线播放 | 91一区二区三区在线观看 | 国产高清一区二区 | 国产一区二区三区四区 | 成人毛片视频在线播放 | 成人毛片视频免费 | 国产91在线观看 | 国产成人精品综合 | 国产精品久久久爽爽爽麻豆色哟哟 | 国产成人免费观看 | 欧美99| 国产精品久久久久久久久久久久 | 国产免费观看视频 | 一a一片一级一片啪啪 | 99免费精品视频 | 91国产视频在线观看 | 中文福利视频 | 久久精品国产清自在天天线 | 欧美成人一区二区三区片免费 |