使用webpack-dev-server處理跨域請(qǐng)求的方法
在前端調(diào)試的時(shí)候,跨域一直都是一個(gè)比較麻煩的問(wèn)題,這個(gè)在之前的文章 關(guān)于跨域問(wèn)題的一個(gè)解決方法 中其實(shí)已經(jīng)討論了一些可以使用的方法。
如果要使用 JSONP,第一是需要修改的地方比較多,而且也不太符合前端發(fā)展的大趨勢(shì),如果使用 CORS 的話并沒(méi)有 application/json 類(lèi)型。而且更重要的是這只是在前端調(diào)試時(shí)候的需求,并不是在上線以后的需求,所以對(duì)后端有太多的入侵也不好。
所以就有一個(gè)念想突然在大腦中閃過(guò)——加入有一個(gè)代理不就可以解決這個(gè)問(wèn)題了?但是又想了一下寫(xiě)起來(lái)還挺麻煩,于是就被擱置了。
直到前幾天 Stone 提到其實(shí) webpack-dev-server 早就想到并且已經(jīng)幫我們實(shí)現(xiàn)了。
于是,我就在一個(gè) Vue 項(xiàng)目中進(jìn)行測(cè)試,發(fā)現(xiàn)真的很贊,既可以本地 Server 熱加載,還可以直接跨域調(diào)用遠(yuǎn)程 API,完美解決了之前遇到的所有問(wèn)題。
接下來(lái)我簡(jiǎn)要介紹一下步驟(以一個(gè) Vue 腳手架建立的 webpack 項(xiàng)目為例):
首先檢查 build/webpack.dev.conf.js 中是否有
proxy: config.dev.proxyTable,
這個(gè)配置項(xiàng),如果被注釋掉,請(qǐng)打開(kāi)注釋?zhuān)绻麤](méi)有,請(qǐng)加入到 devServer 對(duì)象中
然后在 config/index.js 中的 dev 對(duì)象中加入 proxyTable 配置項(xiàng):
proxyTable: { '/**': { target: 'http://api.xxx.com', changeOrigin: true, secure: false } },
前面的鍵 /** 意思是代理所有請(qǐng)求,如果代理某些請(qǐng)求,可以將其改為諸如 /api 之類(lèi)的字符串。
后面的 target 就是要代理到的網(wǎng)站,changeOrigin 的意思就是把 http 請(qǐng)求中的 Origin 字段進(jìn)行變換,在瀏覽器接收到后端回復(fù)的時(shí)候,瀏覽器會(huì)以為這是本地請(qǐng)求,而在后端那邊會(huì)以為是在站內(nèi)的調(diào)用。
這樣,通過(guò)這個(gè)簡(jiǎn)單的配置,就完美地解決了跨域的問(wèn)題。
之后,在直接運(yùn)行
npm run dev
的時(shí)候,就可以將測(cè)試前端中的 ajax 請(qǐng)求代理到后端服務(wù)器進(jìn)行測(cè)試?yán)玻?/p>
最后,貼上官方文檔,具體的配置大家可以參考這里:
https://webpack.js.org/configuration/dev-server/#devserver-proxy
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- webpack-dev-server原理解析及跨域解決方法
- 'webpack-dev-server'?不是內(nèi)部或外部命令也不是可運(yùn)行的程序?或批處理文件的最新解決方法
- webpack-dev-server核心概念案例詳解
- 詳解Webpack-dev-server的proxy用法
- 使用webpack3.0配置webpack-dev-server教程
- 淺談webpack-dev-server的配置和使用
- 詳解webpack-dev-server 設(shè)置反向代理解決跨域問(wèn)題
- 詳解webpack-dev-server的簡(jiǎn)單使用
- webpack-dev-server自動(dòng)更新頁(yè)面方法
- webpack-dev-server 的 host 配置 0.0.0.0的方法
相關(guān)文章
ros::spin() 和 ros::spinOnce()函數(shù)的區(qū)別及詳解
這篇文章主要介紹了ros::spin() 和 ros::spinOnce()函數(shù)的區(qū)別及詳解的相關(guān)資料,本文介紹的非常詳細(xì),具有參考借鑒價(jià)值,感謝興趣的朋友一起看看吧2016-10-10js實(shí)現(xiàn)3D圖片環(huán)展示效果
本文主要介紹了js實(shí)現(xiàn)3D圖片環(huán)展示效果的實(shí)例,具有很好的參考價(jià)值。下面跟著小編一起來(lái)看下吧2017-03-03利用JavaScript檢測(cè)CPU使用率自己寫(xiě)的
這篇文章主要介紹了自己寫(xiě)的一個(gè)利用JavaScript檢測(cè)CPU使用率的方法,需要的朋友可以參考下2014-03-03JS攜帶參數(shù)實(shí)現(xiàn)頁(yè)面跳轉(zhuǎn)功能
這篇文章主要介紹了js攜帶參數(shù)實(shí)現(xiàn)頁(yè)面跳轉(zhuǎn),實(shí)現(xiàn)方法也很簡(jiǎn)單,方式一是跳轉(zhuǎn)路徑攜帶參數(shù),第二種方法是通過(guò)sessionStorage傳遞,需要的朋友可以參考下2022-11-11nodejs讀取本地中文json文件出現(xiàn)亂碼解決方法
在本篇文章中我們給大家分享了關(guān)于nodejs讀取本地中文json文件出現(xiàn)亂碼的解決方法,需要的朋友們可以學(xué)習(xí)下。2018-10-10JavaScript動(dòng)態(tài)生成二維碼圖片
本文給大家介紹js動(dòng)態(tài)生成二維碼圖片的相關(guān)內(nèi)容,感興趣的朋友一起學(xué)習(xí)吧2016-04-04利用Promise自定義一個(gè)GET請(qǐng)求的函數(shù)示例代碼
這篇文章主要給大家介紹了關(guān)于如何利用Promise自定義一個(gè)GET請(qǐng)求的函數(shù)的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用Promise具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-03-03使用bootstraptable插件實(shí)現(xiàn)表格記錄的查詢(xún)、分頁(yè)、排序操作
這篇文章主要介紹了 使用bootstraptable插件實(shí)現(xiàn)表格記錄的查詢(xún)、分頁(yè)、排序操作,需要的朋友可以參考下2017-08-08