vue-cli 前端开发,后台接口跨域代理调试问题
使用 webpack的方式开发的时候,前台开发过程中需要调用很多后台的数据接口,但是通常前后台分离的开发方式,后台的接口数据很可能是不方便或者是不能在前端同学的电脑上运行的,也就出现了所谓的跨域问题。
当然,开发过程中可以使用模拟的json数据来替代,但是实际的测试环境,以及联调环节还是必须要运行后台开发人员的数据比较保险,特别是存在条件式的判断等问题的时候。
其实我们此时只要对脚手架的配置文件进行简单的修改就可以实现了。
第一步,实现跨域代理请求。
修改 /config/index.js 里面的 dev下的proxytable
/**
* 前端开发数据交互node端代理的说明
* 示例中: /api/act 代表接口的基本地址
* @target: 目标服务器的地址
* @ changeOrigin: 是否跨域(一般都可以设置为true)
* @ pathRewrite: 将当前路径,重定向到目标路径,可以用于调试
* 以下示例,即可将 this.$http.get('/api/act',...) 转发到 this.$http.get('http://localhost:8080/static/mock',...)
*/
proxyTable: {
'/api/act': {
target: 'http://localhost:8080/',
changeOrigin: true,
pathRewrite: {
'^/api/act': '/static/mock'
}
}
}
经过以上设置,即可在vue文件中使用
this.$http.get('/api/act/xxx.json') 的方式请求数据,请求会自动转发到 项目目录下的 /static/mock/xxx.json
如果需要连接测试同学的服务器(通常都是局域网),就可以将上面的 target 修改为测试同学的ip及端口即可。 当然 接口规则遵循restFull最好。
第二步,实现请求类型的转发。
此时,还存在一个问题,虽然以上代理解决了请求转发的问题,能确保测试环境迁移到生产环境无须再次修改接口名称。但是标准的请求协议,可不能都用get,所以如果我们的数据是自己编写的静态json模拟数据,那它只能接受get请求,对于post put delete 等是无法正确相应的。 所以,接下来我们还需要实现将所以类型的请求转发为get请求,这样在测试环境,就可以尽情的使用静态的json文件来模拟各种请求的数据了。
在/build/dev-server.js中 大约 46行
// proxy all method to GET
app.use(function(req,res,next){
req.method = 'GET';
next();
});
这样,就可以实现所有的请求类型全部被转为get请求进行了。 而与后台联调的时候,请求真实的接口时,请注意将这里注释掉,并重启服务。否则所有的请求都会变成get哦。
好了,这样就完美的实现了,前后端完全分离调试数据的功能了。
vue-cli 前端开发,后台接口跨域代理调试问题的更多相关文章
- Next.js 配置接口跨域代理转发
使用 create-next-app 创建的 Next.js 项目配置接口跨域代理转发需要用到 custom server 功能. 先安装好 express 和 http-proxy-middlewa ...
- 用 Nokitjs 解决前端开发中的跨域问题
问题 在开发一些「单页应用」时,通常会使用 Ajax 和服务器通讯,比如 RESTful API,通常「前端」和「服务端 API」可能是有不同人员在负责,也不在同一个工程下,那么开发过程中就可能会遇到 ...
- vue proxyTable 接口跨域请求调试
在不同域之间访问是比较常见,在本地调试访问远程服务器....这就是有域问题. VUE解决通过proxyTable: 在 config/index.js 配置文件中 dev: { env: requir ...
- vue proxyTable 接口跨域请求调试(五)
在不同域之间访问是比较常见,在本地调试访问远程服务器....这就是有域问题. VUE解决通过proxyTable: 在 config/index.js 配置文件中 dev: { env: requir ...
- Vue proxyTable 解决开发环境的跨域问题
在 config/index.js 配置文件中,添加 dev: { proxyTable: { '/ssp/withdraw': { target: 'http://dev.home.phiwifi. ...
- Nginx解决前端调用后端接口跨域问题
1.项目中遇到的问题描述: 前端调用zuul统一网关服务接口,请求状态码200,但是无返回数据. 浏览器控制台报错信息:No Access-Control-Allow-Origin header i ...
- 转换:使用vue-axios和vue-resource解决vue中调用网易云接口跨域的问题
本人配置成功https://segmentfault.com/a/1190000011072725
- 前端vue开发中的跨域问题解决,以及nginx上线部署。(vue devServer与nginx)
前言 最近做的一个项目中使用了vue+springboot的前后端分离模式 在前端开发的的时候,使用vue cli3的devServer来解决跨域问题 上线部署则是用的nginx反向代理至后台服务所开 ...
- vue开发环境配置跨域,一步到位
本文要实现的是:使用vue-cli搭建的项目在开发时配置跨域,上线后不做任何任何修改,接口也可以访问,前端跨域解决方案 production:产品 生产环境 development:开发 开发环境 1 ...
随机推荐
- snmp之GenericAddress
GenericAddress 注册地址类型,而不是默认的,第一次调用解析(java.lang.String的)方法之前,设置系统属性ADDRESS_TYPES_PROPERTIES. 这个类涉及到了工 ...
- S2_OOP第三章
第一章 多态 概念 多态是具有表现多种型生态的能力的特征,同一个实现接口,使用不同的实例而执行不同的操作 子类转换父类(向上转型) 用父类接受子类,向上转型 向上转型的规则: 讲一个父类的引用志向一个 ...
- nodejs后台集成富文本编辑器(ueditor)
1 下载ueditor nodejs版本 2 复制public目录下面的文件 到项目静态资源public文件夹下 3 在项目根目录创建ueditor文件夹 要复制进来的内容为 4 在根目录的 uedi ...
- [转]python单元测试unittest
单元测试作为任何语言的开发者都应该是必要的,因为时隔数月后再回来调试自己的复杂程序时,其实也是很崩溃的事情.虽然会很快熟悉内容,但是修改和调试将是一件痛苦的事情,如果你在修改了代码后出现问题的话,而单 ...
- HDU3844Tour (好题)
题意: 有N个点,M个单向边,现在要你设计N条路线覆盖所有的点,每个点都属于且值属于一个环.(为什么是N条边:和最小生成树为什么有N-1条边是一样的证明). 解析: 每个点都有一个喜欢对象(出度 ...
- MVC中重写RoleProvider角色管理
/* 数据表SQL脚本 if exists (select * from dbo.sysobjects where id = object_id(N'[dbo].[FK_UsersInRoles_Ro ...
- 玩转INotifyPropertyChanged和ObservableCollection
转载: http://www.cnblogs.com/Jax/archive/2009/10/13/1582128.html 本文的代码都是基于WPF的,对于Silverlight,这些技术也同样 ...
- python 设计模式,“多”例模式
版本1:一个账号不能同时是司机乘客. #-*- coding:utf-8 -*- ''' Created on 2016年8月2日 @author: yangfanholiday ''' class ...
- ceph在品高云中的实践
ceph简介 ceph是业界目前人气最高的开源存储项目之一,关于其定义在官网是这样的:"Ceph is a unified, distributed storage system desig ...
- 【解决方案】M2Crypto不支持python3
问题现象:python3的环境下,导入M2Crypto模块报错 "ModuleNotFoundError: No module named 'M2Crypto",通过pip ins ...