vue-cil之a(chǎn)xios的二次封裝與proxy反向代理使用說明
Axios與proxy反向代理
Axios 是一個基于 promise 的 HTTP 庫,可以用在瀏覽器和 node.js 中。
1、Axios 的特性
- 從瀏覽器中創(chuàng)建 XMLHttpRequests
- 從 node.js 創(chuàng)建 http 請求
- 支持 Promise API
- 攔截請求和響應(yīng)
- 轉(zhuǎn)換請求數(shù)據(jù)和響應(yīng)數(shù)據(jù)
- 取消請求
- 自動轉(zhuǎn)換 JSON 數(shù)據(jù)
- 客戶端支持防御 XSRF
2、Axios 的安裝
npm i axios # 或者 yran add axios
3、Axios 與proxy反向代理的使用
在要進行使用的文件(request.js)里面導(dǎo)入
// 這是實現(xiàn) axios 的二次分裝
// 導(dǎo)入下載好的包
impront axios from 'axios'
// 創(chuàng)建 axios 實例
const service = axios.create({
? ? // 添加要對接的后端 url 接口
? ? // bassUrl: '<url>',
? ? // 設(shè)置超時時間
? ? timeout: 3000
})
// 請求攔截
service.interceptors.request.use(config => {
? ? // 可以添加一些響應(yīng)頭信息等
? ??
? ? return config
})?
// 響應(yīng)攔截
service.interceptors.response.use(res => {
? ? console.log('請求攔截', res)
? ? return res
})
// 導(dǎo)出
export default service如果是對接多個后端接口,前端應(yīng)用和后端API服務(wù)器沒有運行在同一個主機上,你需要在開發(fā)環(huán)境下將API請求代理到 API服務(wù)器,就在vue.config.js 中書寫如下代碼
// vue.config.js
module.exports = {
? devServer:{
? ? ? // 更改端口號
? ? ? port: 9550,
? ? ? // 是否自動打開瀏覽器
? ? ? open: true,
? ? ? proxy: {
? ? ? ?// 這里是訪問到以 /api 開頭的 url 的時候會代理到target 目標(biāo)上
? ? ? ?? ?'/api': {
? ? ? ?? ??? ?target:'<url>',
? ? ? ?? ??? ?ws: true,
? ? ? ?? ??? ?changeOrigin:true,
? ? ? ?? ??? ?// 重新修改路徑
? ? ? ?? ??? ?pathRewrite: {
? ? ? ?? ??? ??? ?'^/api': ''
? ?? ??? ??? ?}
? ?? ??? ?}
? ?? ?}
? }
}注:為什么要重新修改路徑,因為在發(fā)送請求后會在url中多拼接上一個 ’‘ /api ’‘ ,但是我們獲取數(shù)據(jù)又不需要這個才能拿到,所以就要重新修改,把他拿掉;拿掉之后就可以獲取到數(shù)據(jù)了
最后那個地方需要就直接導(dǎo)入service 然后調(diào)用就行了
axios反向代理proxy個人理解
使用反向代理proxy的原因
首先需要了解瀏覽器的同源策略,同源就是說比如你VUE的項目地址是“http://localhost:8080”,而你后端項目啟動地址是‘http://localhost:9999’,兩者中協(xié)議(http)、域名(localhost)相同,但是端口號(:xxxx)vue是8080,而后端是9999不相同,所以產(chǎn)生跨域,需要使用反向代理。(若兩者滿足協(xié)議、域名、端口號相同則不存在跨域問題)。
反向代理在我個人理解就是給你vue項目訪問后端資源時給你套上的一個殼,讓瀏覽器認(rèn)為本次請求是同源的,瀏覽器就不會進行攔截,數(shù)據(jù)可以正常返回(類似vpn原理吧)。
proxy基本配置
module.exports = {
?? ?devServer: {
?? ??? ?proxy: {
?? ??? ??? ?'/proxyurl':{
?? ??? ??? ??? ?target:'http://localhost:9999',//起同源作用的url 簡單來說就是你要訪問的服務(wù)器
?? ??? ??? ??? ?//ws: true, 這個是 開啟websocket
?? ??? ??? ??? ?changeOrigin: true,//字面意思:更改源點 很多人說是開啟跨域 也可以這么理解
?? ??? ??? ??? ?pathRewrite: {
?? ??? ??? ??? ??? ?'^/proxyurl': '' //還有一種寫法是'^/proxyurl': '/' 自測
?? ??? ??? ??? ?}
?? ??? ??? ?}
?? ??? ?}
?? ?}
}//寫個最簡單的例子用法
//前端項目地址是 http://localhost:8080
//后端項目地址是 http://localhost:9999
?? ?axios.get("/proxyurl/user/getalluser").then(res => {
?? ??? ?console.log(res);
?? ?});解釋這個例子:
顯然我們是通過vue項目訪問了后端資源,拋開代理單看這段代碼,是以http://localhost:8080/proxyurl/user/getalluser請求資源的。
但是有了反向代理,反向代理看到了你這段url中出現(xiàn)了’/proxyurl‘,反向代理起作用,將’/proxyurl‘前面這段’http://localhost:8080‘替換成了’http://localhost:9999‘,這時候請求資源的url變?yōu)?lsquo;http://localhost:9999/proxyurl/user/getalluser’。
但是我們又配置了一項pathRewrite: {'^/proxyurl': ''},'^/proxyurl'是正則表達式,它會匹配你url中的字符串。這一選項的代碼意思是,將url中的’/proxyurl‘替換為空字符串。則現(xiàn)在的url是http://localhost:9999/user/getalluser
ps:通常我們會將axios封裝,可以在創(chuàng)建axios實例時這樣寫
export function request(config){
? ? let axiosInstance = axios.create({
? ? ? ? baseURL: '/proxyurl', //在調(diào)用時拼接上后面的url就可以了
? ? ? ? timeout: 5000
? ? });
? ? return axiosInstance(config);
}
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
vue常用的數(shù)字孿生可視化的自適應(yīng)方案
這篇文章主要為大家介紹了vue常用的數(shù)字孿生可視化的自適應(yīng)方案詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-07-07
VueJs單頁應(yīng)用實現(xiàn)微信網(wǎng)頁授權(quán)及微信分享功能示例
本篇文章主要介紹了VueJs單頁應(yīng)用實現(xiàn)微信網(wǎng)頁授權(quán)及微信分享功能示例,具有一定的參考價值,有興趣的可以了解一下2017-07-07
前端vue實現(xiàn)的h5頁面接入微信支付流程(jsapi方式)
vue實現(xiàn)微信支付有三種方式,第一種方式是PC端支付,第二種方式是H5支付,第三種方式是微信公眾號支付,這篇文章主要給大家介紹了關(guān)于前端vue實現(xiàn)的h5頁面接入微信支付流程,文中介紹的方法是利用jsapi方式,通過代碼將實現(xiàn)的方法介紹的非常詳細(xì),需要的朋友可以參考下2024-01-01

