首先在 测试环境的配置 webpack.dev.config.js 的 plugins 添加;
new webpack.DefinePlugin({
'process.env': {
NODE_ENV: '"development"'
}
}),
然后在初始化websocket的时候判断当前环境是开发环境还是测试环境
initWebSocket() {//webSocket初始化
let path = window.location.host;
//这里是关键,可以判断当前环境是生产环境还是开发环境,开发环境加测试域名即可调试,生产环境由于代码要放到服务器获取本地域名即可
if(process.env.NODE_ENV === 'development') {
path = 'baidu.com'; //这里改成你测试的域名
} else {
path = window.location.host;
}
const wsuri = 'wss://' + path + "/api/scanJump/ws.jhtml"; //如果是wss协议,这里path一定要域名才能正常连接 ip+端口的方式不行(注:这里/api是设置了反向代理解决了跨域问题,详情看下面链接)
this.websock = new WebSocket(wsuri);
this.websock.onopen = function(event) {
console.log("WebSocket:已连接");
console.log(event);
};
this.websock.onmessage = function(event) {
console.log("WebSocket:消息",event);
console.log(event);
};
this.websock.onerror = function(event) {
console.log("WebSocket:发生错误 ");
console.log(event);
};
this.websock.onclose = function(event) {
console.log("WebSocket:已关闭");
console.log(event);
};
},
前言
在项目开发中,接口联调的时候一般都是同域名下,且不存在跨域的情况下进行接口联调,但是当我们现在使用vue-cli进行项目打包的时候,我们在本地启动服务器后,比如本地开发服务下是 http://localhost:8080
这样的访问链接,但是我们的接口地址是 http://www.xxx.com/save/post
这样的,我们这样直接使用就会存在跨域的请求,导致接口请求不成功。
那么我们该怎么解决呢?
只要将接口地址通过代理的方式映射到本地,让我们的本地开发也可以使用相对根目录的方式请求接口。
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': ''}
}
}