詳解如何解決vue開發請求數據跨域的問題(基於瀏覽器的配置解決)

這篇文章主要介紹了詳解如何解決vue開發請求數據跨域的問題(基於瀏覽器的配置解決),小編覺得挺不錯的,現在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧

在用vue做前端開發的時候,因爲一般跑vue使用的webpack自帶的node服務,而我們實際要使用的數據確是後臺服務器上的,所以這就涉及到服務器請求跨域的問題。本來在諸如axios之類的網絡請求參數裏面配置

withCredentials: true,

就可以解決跨域問題的,但是現在瀏覽器比如chorme有做了新的跨域限制,比如要服務器端配置允許跨域才行,詳見跨域問題解決,是英文的,看起來需要花點功夫;那有沒有不需要服務器端配置就能解決瀏覽器的跨域問題的辦法呢?答案肯定是有的!!

這裏就說chorme吧,因爲chorme基本都是前端主流瀏覽器了,配置方法如下:

版本號49之前的跨域設置

具體做法爲:

1.下載並安裝好chorme瀏覽器後在桌面找到瀏覽器快捷圖標並點擊鼠標右鍵的屬性一欄。

2.在屬性頁面中的目標輸入框里加上   --disable-web-security  如下圖所示:

3.點擊應用和確定後關閉屬性頁面,並打開chrome瀏覽器。如果瀏覽器出現提示“你使用的是不受支持的命令標記 --disable-web-security”,那麼說明配置成功。

版本號49之後的chrome跨域設置

chrome的版本升到49之後,跨域設置比以前嚴格了,在打開命令上加--disable-web-security之後還需要給出新的用戶個人信息的目錄。衆所周知chrome是需要用gmail地址登錄的瀏覽器,登錄後就會生成一個存儲個人信息的目錄,保存用戶的收藏、歷史記錄等個人信息。49版本之後,如果設置chrome瀏覽器爲支持跨域模式,需要指定出一個個人信息目錄,而不能使用默認的目錄,估計是chrome瀏覽器怕用戶勿使用跨域模式泄露自己的個人信息(主要是cookie,很多網站的登錄token信息都是保存在cookie裏)。

具體做法爲:

1.在電腦上新建一個目錄,例如:C:\MyChromeDevUserData

2.在屬性頁面中的目標輸入框里加上   --disable-web-security --user-data-dir=C:\MyChromeDevUserData,--user-data-dir的值就是剛纔新建的目錄。

3.點擊應用和確定後關閉屬性頁面,並打開chrome瀏覽器。

再次打開chrome,發現有“--disable-web-security”相關的提示,說明chrome又能正常跨域工作了。

跨域成功後,首頁換成了google的welcome頁面,同時原來收藏的鏈接和歷史記錄都不見了,而C:\MyChromeDevUserData目錄下則生成了新的個人信息相關的文件。

這樣就解決了諸如

報錯的問題,一個坑給填滿了,後面還有很多坑需要去填,哈哈!!!

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持神馬文庫。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章