使用 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 api requests
Object.keys(proxyTable).forEach(function (context) {
的上方,增加请求类型代理的内容
// proxy all method to GET
app.use(function(req,res,next){
req.method = 'GET';
next();
});

这样,就可以实现所有的请求类型全部被转为get请求进行了。 而与后台联调的时候,请求真实的接口时,请注意将这里注释掉,并重启服务。否则所有的请求都会变成get哦。

好了,这样就完美的实现了,前后端完全分离调试数据的功能了。

vue-cli 前端开发,后台接口跨域代理调试问题的更多相关文章

  1. Next.js 配置接口跨域代理转发

    使用 create-next-app 创建的 Next.js 项目配置接口跨域代理转发需要用到 custom server 功能. 先安装好 express 和 http-proxy-middlewa ...

  2. 用 Nokitjs 解决前端开发中的跨域问题

    问题 在开发一些「单页应用」时,通常会使用 Ajax 和服务器通讯,比如 RESTful API,通常「前端」和「服务端 API」可能是有不同人员在负责,也不在同一个工程下,那么开发过程中就可能会遇到 ...

  3. vue proxyTable 接口跨域请求调试

    在不同域之间访问是比较常见,在本地调试访问远程服务器....这就是有域问题. VUE解决通过proxyTable: 在 config/index.js 配置文件中 dev: { env: requir ...

  4. vue proxyTable 接口跨域请求调试(五)

    在不同域之间访问是比较常见,在本地调试访问远程服务器....这就是有域问题. VUE解决通过proxyTable: 在 config/index.js 配置文件中 dev: { env: requir ...

  5. Vue proxyTable 解决开发环境的跨域问题

    在 config/index.js 配置文件中,添加 dev: { proxyTable: { '/ssp/withdraw': { target: 'http://dev.home.phiwifi. ...

  6. Nginx解决前端调用后端接口跨域问题

    1.项目中遇到的问题描述: 前端调用zuul统一网关服务接口,请求状态码200,但是无返回数据. 浏览器控制台报错信息:No  Access-Control-Allow-Origin header i ...

  7. 转换:使用vue-axios和vue-resource解决vue中调用网易云接口跨域的问题

    本人配置成功https://segmentfault.com/a/1190000011072725

  8. 前端vue开发中的跨域问题解决,以及nginx上线部署。(vue devServer与nginx)

    前言 最近做的一个项目中使用了vue+springboot的前后端分离模式 在前端开发的的时候,使用vue cli3的devServer来解决跨域问题 上线部署则是用的nginx反向代理至后台服务所开 ...

  9. vue开发环境配置跨域,一步到位

    本文要实现的是:使用vue-cli搭建的项目在开发时配置跨域,上线后不做任何任何修改,接口也可以访问,前端跨域解决方案 production:产品 生产环境 development:开发 开发环境 1 ...

随机推荐

  1. Django内置的用户认证

    认证登陆 在进行用户登陆验证的时候,如果是自己写代码,就必须要先查询数据库,看用户输入的用户名是否存在于数据库中: 如果用户存在于数据库中,然后再验证用户输入的密码,这样一来就要自己编写大量的代码. ...

  2. MySQL or MariaDB 错误解决方法之报错代码1045

    phpMyAdmin登录报错:mysqli_real_connect(): (28000/1045): Access denied for user 'root'@'localhost' (using ...

  3. ASP.NET没有魔法——目录

    ASP.NET没有魔法——开篇-用VS创建一个ASP.NET Web程序 ASP.NET没有魔法——为什么使用ASP.NET ASP.NET没有魔法——第一个ASP.NET应用<MyBlog&g ...

  4. VNC实现Windows远程访问Ubuntu 16.04(无需安装第三方桌面)

    本文主要是讲解如果理由VNC实现Windows远程访问Ubuntu 16.04,其实网上有很多类似教程,但是很多需要安装第三方桌面(xfce桌面等等),而且很多人不太喜欢安装第三方桌面,很多人像笔者一 ...

  5. Quartz.NET实现作业调度

    一.Quartz.NET介绍 Quartz.NET是一个强大.开源.轻量的作业调度框架,是 OpenSymphony 的 Quartz API 的.NET移植,用C#改写,可用于winform和asp ...

  6. XML编程

     XML编程 XML及其语法 XML约束之DTD XML编程(CRUD---Create Read Update Delete) XML约束之Schema XML语法: XML文档的组成: 一个X ...

  7. ZPL条码打印类

    using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.I ...

  8. 实用的Jquery选项卡TAB

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

  9. 大数据算法设计模式(1) - topN spark实现

    topN算法,spark实现 package com.kangaroo.studio.algorithms.topn; import org.apache.spark.api.java.JavaPai ...

  10. 学习总结---OSPF协议

    总结: 1.ospf协议报文不会泛洪扩散,而是逐级路由器处理后,再从所有ospf启用端口发送出去,也就是说,只能从邻居接收到ospf报文,报文的源ip是邻居的ip地址,目的ip是组播ip. 2.开启o ...