首页 > 编程 > JavaScript > 正文

详解vue-cli本地环境API代理设置和解决跨域

2019-11-19 15:33:14
字体:
来源:转载
供稿:网友

前言

我们在使用vue-cli启动项目的时候npm run dev便可以启动我们的项目了,通常我们的请求地址是以localhost:8080来请求接口数据的,localhost是没有办法设置cookie的。

我们可以在vue-cli配置文件里面设置一个代理,跨域的方法有很多,通常需要后台来进行配置。我们可以直接通过node.js代理服务器来实现跨域请求。

vue proxyTable接口跨域请求调试

在vue-cli项目中的config文件夹下的index.js配置文件中,dev长这样子:

dev: {  env: require('./dev.env'),  port: 8080,  autoOpenBrowser: true,  assetsSubDirectory: 'static',  assetsPublicPath: '/',  proxyTable: {},    cssSourceMap: false }

服务器提供的接口如果长这样https://www.exaple.com/server_new/login,我们把域名提取出来如https://www.exaple.com;

在config中新建一个文件命名为proxyConfig.js :

module.exports = { proxy: {    '/apis': {  //将www.exaple.com印射为/apis      target: 'https://www.exaple.com', // 接口域名      changeOrigin: true, //是否跨域      pathRewrite: {        '^/apis': ''  //需要rewrite的,      }           } }}

config文件夹下的index.js引入proxyConfig.js:

var proxyConfig = require('./proxyConfig')

config文件夹下的index.js中的dev改成:

dev: {  env: require('./dev.env'),  port: 8080,  autoOpenBrowser: true,  assetsSubDirectory: 'static',  assetsPublicPath: '/',  proxyTable: proxyConfig.proxy,  cssSourceMap: false }

重启项目npm run dev:

你会发现出现了这个

 

这个时候我们已经设置好了本地API代理了

修改本地hosts文件

文件路径一般是C:/Window/System32/drivers/etc,打开hosts文件,在这一段下面把localhost设置进去

# localhost name resolution is handled within DNS itself.# 127.0.0.1    localhost# ::1       localhost127.0.0.1          activate.adobe.com127.0.0.1          practivate.adobe.com127.0.0.1          lmlicenses.wip4.adobe.com127.0.0.1          lm.licenses.adobe.com127.0.0.1          na1r.services.adobe.com127.0.0.1          hlrcv.stage.adobe.comlocalhost          www.exaple.com    

搞定

此时我们已经完全解决了跨域问题,以及本地测试后台无法向我们本地环境设置cookie的情况了。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持武林网。

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表