ajax請求前端跨域問題原因及解決方案
一、跨域是怎么形成的
當(dāng)我們請求一個url的 協(xié)議、域名、端口三者之間任意一個與當(dāng)前頁面url的協(xié)議、域名、端口 不同這種現(xiàn)象我們把它稱之為跨域
跨域會導(dǎo)致:
1、無法讀取非同源網(wǎng)頁的 Cookie、LocalStorage 和 IndexedDB
2、無法接觸非同源網(wǎng)頁的 DOM
3、無法向非同源地址發(fā)送 AJAX 請求(可以發(fā)送,但瀏覽器會拒絕接受響應(yīng))
二、導(dǎo)致跨域的根本原因
導(dǎo)致跨域的根本原因是請求瀏覽器的同源策略導(dǎo)致的 ,而跨域請求報(bào)錯的原因是: 瀏覽器同源策略 && 請求是ajax類型 && 請求確實(shí)跨域了
三、解決方法
給大家介紹三種方法 jsonp,cors,代理轉(zhuǎn)發(fā)
1 、JSONP
JSONP 是服務(wù)器與客戶端跨源通信的常用方法。最大特點(diǎn)就是簡單適用,兼容性好(兼容低版本IE),缺點(diǎn)是只支持get請求,不支持post請求。
原理:img、srcipt,link標(biāo)簽的src或href屬性不受同源策略限制,可以用來作為請求,后端接受請求后返回一個回調(diào)函數(shù)callback,調(diào)用前端已經(jīng)定義好的函數(shù),從而實(shí)現(xiàn)跨域請求。
舉個很簡單的例子 : 我們通過img標(biāo)簽的src屬性, 請求一個網(wǎng)絡(luò)地址的圖片 ,這就是非同源請求了 ,但是由于瀏覽器的同源策略只對ajax請求有效所以 我們的請求不會受到影響 。換句話來說 只有ajax請求才會產(chǎn)生跨域問題。
2、 CORS
CORS 是跨域資源分享(Cross-Origin Resource Sharing)的縮寫。它是 W3C 標(biāo)準(zhǔn),屬于跨源 AJAX 請求的根本解決方法。
CORS允許任何類型的請求。在使用CORS來訪問數(shù)據(jù)的時候,客戶端不需要更改任何數(shù)據(jù)訪問邏輯。所有的一切工作都是在服務(wù)端及瀏覽器之間自動完成的。前端代碼與發(fā)送普通Ajax請求沒有差異,我們只需在服務(wù)端設(shè)置即可(后端的活)
3 、代理轉(zhuǎn)發(fā)
在前端服務(wù)和后端接口服務(wù)之間 架設(shè)一個中間代理服務(wù),它的地址保持和前端服務(wù)器一致,那么:
這樣,我們就可以通過中間這臺服務(wù)器做接口轉(zhuǎn)發(fā),在開發(fā)環(huán)境下解決跨域問題,看起來好像挺復(fù)雜,其實(shí)vue-cli已經(jīng)為我們內(nèi)置了該技術(shù),我們只需要按照要求配置一下即可。
vue.config.js 的devServer(開發(fā)環(huán)境)里 配置代理服務(wù)器 通過這個代理服務(wù)器發(fā)送請求 這樣就不純在跨域的問題了 代碼如下:
module.exports = { devServer: { // ... 省略 // 代理配置 proxy: { // 如果請求地址以/api打頭,就出觸發(fā)代理機(jī)制 // http://localhost:9588/api/login -> http://localhost:3000/api/login '/api': { target: 'http://localhost:3000' // 我們要代理的真實(shí)接口地址 } } } } }
記得baseURL里的根路徑 是相對地址,而不能是絕對地址
以上就是ajax請求前端跨域問題原因及解決方案的詳細(xì)內(nèi)容,更多關(guān)于ajax跨域問題原因及解決的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
微信小程序api列表匯總包括網(wǎng)絡(luò)API,媒體API,文件API ,微信小程序支付流程,位置API,界面API等
這篇文章主要介紹了微信小程序api列表匯總包括網(wǎng)絡(luò)API,媒體API,文件API ,數(shù)據(jù)API,位置API,界面API,微信小程序支付流程,微信小程序登錄流程等,需要的朋友可以參考下2022-12-12javascript getElementsByClassName實(shí)現(xiàn)代碼
根據(jù)元素clsssName得到元素集合的函數(shù),需要的朋友可以參考下。2010-10-10JavaScript實(shí)現(xiàn)表單驗(yàn)證案例
這篇文章主要為大家詳細(xì)介紹了JavaScript實(shí)現(xiàn)表單驗(yàn)證案例,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2022-08-08JS數(shù)組的遍歷方式for循環(huán)與for...in
本節(jié)主要介紹了JS數(shù)組的遍歷方式for循環(huán)與for...in,需要的朋友可以參考下2014-07-07第一次動手實(shí)現(xiàn)bootstrap table分頁效果
這篇文章主要為大家詳細(xì)介紹了第一次動手實(shí)現(xiàn)bootstrap table分頁效果的相關(guān)代碼,具有一定的參考價值,感興趣的小伙伴們可以參考一下2016-09-09千萬不要錯過的JavaScript高效對比數(shù)組差異方法
前端開發(fā)中,我們通常需要對比兩個數(shù)組對象的差異。這其中有很多種方法,但是有些方法會帶來一些問題,所以本文為大家準(zhǔn)備了一個高效方法,需要的可以參考一下2023-05-05使用Plupload實(shí)現(xiàn)直接上傳附件至七牛云存儲
這篇文章主要介紹了使用Plupload實(shí)現(xiàn)直接上傳附件至七牛云存儲,需要的朋友可以參考下2014-12-12JS實(shí)現(xiàn)選項(xiàng)卡實(shí)例詳解
這篇文章主要介紹了JS實(shí)現(xiàn)選項(xiàng)卡的方法,結(jié)合實(shí)例形式詳細(xì)講述了JavaScript實(shí)現(xiàn)選項(xiàng)卡的布局與功能實(shí)現(xiàn)的完整步驟及相關(guān)技巧,需要的朋友可以參考下2015-11-11