前言
在项目开发中,接口联调的时候一般都是同域名下,且不存在跨域的情况下进行接口联调,但是当我们现在使用vue-cli进行项目打包的时候,我们在本地启动服务器后,比如本地开发服务下是 http://localhost:8080
这样的访问链接,但是我们的接口地址是 http://www.xxx.com/save/post
这样的,我们这样直接使用就会存在跨域的请求,导致接口请求不成功。
PS:目前用的是webpack 3.6版本,是在Vue-cli中集成的。
那么我们该怎么解决呢?
只要将接口地址通过代理的方式映射到本地,让我们的本地开发也可以使用相对根目录的方式请求接口。
webpack本身自带了代理功能,只要经过简单的配置即可。
我们打开下面路径的文件
config/index.js
在其中的dev
对象里面找到:proxyTable: {}
这里就是配置代理的地方,我们进行如下设置:
dev: {
// 代理配置表,在这里可以配置特定的请求代理到对应的API接口
proxyTable: {
'/api': {
target: 'http://www.xxx.com', // 你接口的域名
secure: false, // 如果是https接口,需要配置这个参数为true
changeOrigin: true, // 如果接口跨域,需要进行这个参数配置为true
pathRewrite: {
'^/api': ''
}
}
},
}
接口地址原本是 /save/post
,但是为了匹配代理地址,在前面加一个 /api
, 因此接口地址需要写成这样的即可生效 /api/save/post
。
注意:
'/api'
为匹配项,target
为被请求的地址,因为请求的 url 中加了前缀'/api'
,而原本的接口是没有这个前缀的,所以需要通过pathRewrite
来重写地址,将前缀'/api'
转为''
或者'/'
。如果本身的接口地址就有'/api
‘ 这种通用前缀,就可以把pathRewrite
删掉。
webpack代理设置请参阅:https://webpack.js.org/configuration/dev-server/#devserver-proxy
有用的配置教程视频:https://ke.qq.com/course/350693?tuin=undefined&taid=2704450712328677
附:
Nginx和webpack配置支持Websocket
一、Nginx配置
map $http_upgrade $connection_upgrade {
default upgrade;
'' close;
}
upstream ws {
server localhost:8081;
server localhost:8082;
}
server {
listen 80;
server_name localhost;
location / {
proxy_pass http://ws;
proxy_http_version 1.1;
proxy_set_header Upgrade $http_upgrade;
proxy_set_header Connection $connection_upgrade;
}
}
二、webpack配置
proxyTable: {
'/api': {
target: 'http://localhost:8081/',
changeOrigin: true,
ws: true,
secure: false,
pathRewrite: {
'^/api': ''
}
}
},
//多代理
proxyTable: {
'/api': {
target: 'http://192.168.0.106:8080',
changeOrigin: true,
pathRewrite: { '^/api': ''}
},
'/ips': {
target: 'http://pv.sohu.com',
changeOrigin: true,
pathRewrite: { '^/ips': ''}
}
}