websocket ---反向代理解决跨域问题

让websocket 可以在本地调试

首先在 测试环境的配置 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);
      };
    },

 

反向代理 解决websocket 跨域问题

前言

在项目开发中,接口联调的时候一般都是同域名下,且不存在跨域的情况下进行接口联调,但是当我们现在使用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': ''}
  }
}

你可能感兴趣的:(杂记)