详解vue-cli项目开发/生产环境代理实现跨域请求


Posted in Javascript onJuly 23, 2019

开发环境中跨域

使用vue-cli创建的项目,开发地址是localhost:8080,需要访问非本机上的接口http://192.168.0.112:8080/cms/queryMaterial。不同域名之间的访问,需要跨域才能正确请求。跨域的方法很多,通常都需要后台配置,不过vue-cli创建的项目,可以直接利用node.js代理服务器,通过修改vue proxyTable接口实现跨域请求。在vue-cli项目中的config文件夹下的index.js配置文件中,修改前的dev:

dev: {
  assetsSubDirectory: 'static', //静态资源根目录的子目录static,也就是dist目录下面的static
  assetsPublicPath: '/', //编译发布的根目录,可配置为资源服务器域名或 CDN 域名
  proxyTable: {}, //proxyTable 代理的接口(可跨域)
  host: 'localhost', 
  port: 8080, //dev-server的端口号,可以自行更改
  autoOpenBrowser: false, //是否自动打开浏览器
  errorOverlay: true,
  notifyOnErrors: true,
  poll: false, 
  useEslint: true,
  showEslintErrorsInOverlay: false,
  devtool: 'cheap-module-eval-source-map',
  cacheBusting: true,
  cssSourceMap: true //默认情况下,关闭 CSS Sourcemaps,因为使用相对路径会报错
 },

只要修改里面的proxyTable: {}

proxyTable: {
 '/cms': { //代理地址
  target: 'http://192.168.0.112:8080', //需要代理的地址
  changeOrigin: true, //是否跨域
  secure: false,
  pathRewrite: {
   '^/cms': '/cms' //本身的接口地址没有'/cms' 这种通用前缀,所以要rewrite,如果本身有则去掉(/cms等价于 www.xxx.com/cms)
  }
 }
},

然后重启项目npm run dev,请求数据时URL前加上“/cms”就可以跨域请求了

this.$axios.get('/cms/queryMaterial', {params: params}) 
  .then((res) => { 
  console.log(res); 
}).catch((err) => { 
  console.log(err); 
})

访问接口若没有安装axios,则需要进行安装

1)安装:npm install axios --save-dev

2)main.js中导入
 import axios from 'axios'; //引入axios进行地址访问
 Vue.prototype.$axios = axios;(注意:不使用use来使用该例,而是用prototype原型来使用)

1、参数proxyTable详解:

vue-cli的config文件里的参数:proxyTable,这个参数主要是一个地址映射表,你可以通过设置将复杂的url简化,例如我们要请求的地址是www.xxx.com/list/1,可以按照如下设置:

proxyTable: {
 '/list': {
  target: 'http://www.xxx.com',
  pathRewrite: {
   '^/list': '/list'
  }
 }
}

这样我们在写url的时候,只用写成/list/1就可以代表www.xxx.com/list/1

那么又是如何解决跨域问题的呢?其实在上面的'list'的参数里有一个changeOrigin参数,接收一个布尔值,如果设置为true,那么本地会虚拟一个服务端接收你的请求并代你发送该请求,这样就不会有跨域问题了,当然这只适用于开发环境。增加的代码如下所示:

proxyTable: {
 '/list': {
  target: 'http://www.xxx.com',
  changeOrigin: true,
  pathRewrite: {
   '^/list': '/list'
  }
 }
}

2、pathRewrite含义

用代理,首先你得有一个标识,告诉他你这个连接要用代理,不然的话,可能你的 html,css,js这些静态资源都跑去代理。所以我们只要接口用代理,静态文件用本地。'/list': {}, 就是告诉node,我接口只要是'/list'开头的才用代理。所以你的接口就要这么写 /list/xx/xx,最后代理的路径就是 http://xxx.xx.com/list/xx/xx。可是不对啊,我正确的接口路径里面没有/list啊,所以就需要 pathRewrite,用'^/list':'', 把'/list'去掉,这样既能有正确标识,又能在请求接口的时候去掉list。当然如果本身的接口中就有/list,那么就可以把pathRewrite这个参数去掉。

生产环境中跨域

1)设置nginx配置文件:

server {
  ...
  location /cms{
    add_header 'Access-Control-Allow-Origin' '*';
    proxy_pass http://192.168.0.112:8080/cms;
  }
  ...
}

2)java后端配置跨域

if (method.equals("OPTIONS")) {
   response.setHeader("Access-Control-Allow-Headers", "accept, content-type");
   response.setHeader("Access-Control-Allow-Method", "POST");
 }
 response.setHeader("Access-Control-Allow-Origin", "*");

设置不同的接口地址

平常我们团队开发时都在公司的局域网内,调用接口也是局域网内部的,但是项目上线时,请求接口是线上服务器端的,那么就有接口之间的来回切换问题。
在使用vue-cli搭建项目以后,做相关配置就可以实现,不用手动更改接口路径,也可以请求不同环境下的接口。

1、设置不同的接口地址

先找到以下文件/config/dev.env.js,/config/prod.env.js,可以看到dev.env.js里面内容如下

'use strict'
const merge = require('webpack-merge')
const prodEnv = require('./prod.env')

module.exports = merge(prodEnv, {
 NODE_ENV: '"development"'
})

这是开发环境的参数配置,然后我们可以再上面文件加入一行代码,如下:这就是本地测试环境请求后台接口的域名

'use strict'
const merge = require('webpack-merge')
const prodEnv = require('./prod.env')

module.exports = merge(prodEnv, {
 NODE_ENV: '"development"',
 API_ROOT: '"//192.168.0.112:8080"'
})

然后找到prod.env.js文件,如下:

'use strict'
module.exports = {
 NODE_ENV: '"production"'
}

我们加入一行代码,如下:这是我们上传服务器以后,请求后台接口的域名

'use strict'
module.exports = {
 NODE_ENV: '"production"',
 API_ROOT: '"//www.baidu.com/api"'
}

2、在代码中调用设置好的参数:

比如我在本项目中重新封装axios(api文件在/src/axios/request.js中),将配置好的接口地址作为baseURL拼接到接口路径中,应用参数部分如下:process.env.API_ROOT

详解vue-cli项目开发/生产环境代理实现跨域请求

最后重新启动项目就可以了,当npm run dev的时候就运行在生产环境,当npm run build的时候就是正式的线上环境。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
js 动态文字滚动的例子
Jan 17 Javascript
asm.js使用示例代码
Nov 28 Javascript
解析jQuery的三种bind/One/Live事件绑定使用方法
Dec 30 Javascript
什么是cookie?js手动创建和存储cookie
May 27 Javascript
js使用removeChild方法动态删除div元素
Aug 01 Javascript
Node.js抓取中文网页乱码问题和解决方法
Feb 10 Javascript
jquery+easeing实现仿flash的载入动画
Mar 10 Javascript
jquery实现浮动在网页右下角的彩票开奖公告窗口代码
Sep 04 Javascript
JavaScript面向对象编写购物车功能
Aug 19 Javascript
使用vue.js2.0 + ElementUI开发后台管理系统详细教程(二)
Jan 21 Javascript
React Native使用fetch实现图片上传的示例代码
Mar 07 Javascript
vue.js的状态管理vuex中store的使用详解
Nov 08 Javascript
vue 地区选择器v-distpicker的常用功能
Jul 23 #Javascript
微信小程序 网络通信实现详解
Jul 23 #Javascript
微信小程序 确认框的实现(附代码)
Jul 23 #Javascript
koa2 从入门到精通(小结)
Jul 23 #Javascript
详解JavaScript 浮点数运算的精度问题
Jul 23 #Javascript
前端插件之Bootstrap Dual Listbox使用教程
Jul 23 #Javascript
JavaScript 格式化数字、金额、千分位、保留几位小数、舍入舍去
Jul 23 #Javascript
You might like
全国FM电台频率大全 - 9 上海市
2020/03/11 无线电
Yii把CGridView文本框换成下拉框的方法
2014/12/03 PHP
Cygwin中安装PHP方法步骤
2015/07/04 PHP
Yii2框架操作数据库的方法分析【以mysql为例】
2019/05/27 PHP
js checkbox(复选框) 使用集锦
2009/04/28 Javascript
js 与或运算符 || && 妙用
2009/12/09 Javascript
几个比较经典常用的jQuery小技巧
2010/03/01 Javascript
javascript (用setTimeout而非setInterval)
2011/12/28 Javascript
jquery鼠标滑过提示title具体实现代码
2013/08/06 Javascript
js弹出层永远居中实现思路及代码
2013/11/29 Javascript
Array栈方法和队列方法的特点说明
2014/01/24 Javascript
JS方法调用括号的问题探讨
2014/01/24 Javascript
javascript生成随机颜色示例代码
2014/05/05 Javascript
根据当前时间在jsp页面上显示上午或下午
2014/08/18 Javascript
每日十条JavaScript经验技巧(二)
2016/06/23 Javascript
jquery实现全选、全不选以及单选功能
2017/03/23 jQuery
JS获取当前地理位置的方法
2017/10/25 Javascript
使用classList来实现两个按钮样式的切换方法
2018/01/24 Javascript
JS左右无缝轮播功能完整实例
2019/05/16 Javascript
vue.js实现三级菜单效果
2019/10/19 Javascript
jQuery 选择方法及$(this)用法实例分析
2020/05/19 jQuery
Python中的异常处理学习笔记
2015/01/28 Python
pymssql数据库操作MSSQL2005实例分析
2015/05/25 Python
Django中URL视图函数的一些高级概念介绍
2015/07/20 Python
python日志记录模块实例及改进
2017/02/12 Python
Python对象类型及其运算方法(详解)
2017/07/05 Python
python中ASCII码字符与int之间的转换方法
2018/07/09 Python
python opencv实现图像边缘检测
2019/04/29 Python
python实现五子棋小程序
2019/06/18 Python
python跨文件使用全局变量的实现
2020/11/17 Python
德国净水壶和滤芯品牌:波尔德PearlCo(家用净水器)
2020/04/29 全球购物
公司培训心得体会
2014/01/03 职场文书
学雷锋倡议书
2015/01/19 职场文书
交通安全教育主题班会
2015/08/12 职场文书
保险公司增员口号
2015/12/25 职场文书
MySql中的json_extract函数处理json字段详情
2022/06/05 MySQL