vue跨域解决方案websocket_2019-05-13 vue-cli webpack 配置 反向代理 解决websocket 跨域问题...

本文介绍了在Vue CLI项目中,如何通过webpack的代理配置解决HTTP和WebSocket跨域问题。详细讲解了在`config/index.js`中设置proxyTable来代理API请求,并提供Nginx配置示例以支持WebSocket跨域。
摘要由CSDN通过智能技术生成

前言

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

附:

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': ''}

}

}

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值