时间:2021-05-25
使用vue-cli调接口的时候,总是会出现垮与问题,因为vue的localhost与访问域名不一致导致。而这一点,开发者显然也想到了,故而在vuejs-templates,也就是vue-cli的使用的模板插件里,有关于API proxy的说明,这个配置就是将localhost映射成访问的域名。
那么何为代理?
代理服务器英文全称是Proxy Server,其功能就是代理网络用户去取得网络信息。形象的说:它是网络信息的中转站。可以简单粗暴理解为把你的域名转换成你访问的域名,(我这么记的,当然可能并不恰当)形成同源,就能访问。
那么在vue里,如何设置代理?
1.config目录找到index.js
2.在dev里添加proxyTable
dev: { env: require('./dev.env'), port: 8080, autoOpenBrowser: true, assetsSubDirectory: 'static', assetsPublicPath: '/', proxyTable: { '/api':{ target:"http://47.93.166.112/BrainPcWeb",//设置你调用的接口域名和端口号 别忘了加http changeOrigin:true, pathRewrite:{ '^/api':''//这里理解成用‘/api'代替target里面的地址,后面组件中我们掉接口时直接用api代替 //比如我要调用'http://40.00.100.133:3002/user/login',直接写‘/api/user/login'即可 } } }这一步为止,你重新run一下vue已经不存在跨域问题了。
如果你想在main.js把api定义成全局变量也可以这样,虽然多此一举。代码如下:
Vue.prototype.HOST = '/api'//这时,你的/api/user/login就可以换成this.HOST/user/login但是注意了
这只是开发环境(dev)中解决了跨域问题,生产环境中真正部署到服务器上如果是非同源还是存在跨域问题
部署到服务器上跨域解决问题,以后项目布置会继续更新。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
vue-cli中可以通过配置proxyTable解决开发环境的跨域问题,具体可以参考这篇文章:Vue-cliproxyTable解决开发环境的跨域问题如果后端接
使用vue-cli搭建的vue项目可以使用在项目内设置代理(proxyTable)的方式来解决跨域问题设置配置项的目录在config下的index.js,主要通
使用Nginx反向代理解决跨域问题(vue.js使用代理去掉vue.js因为跨域而触发的options请求)我们的项目还是需要node.js作为容器的一、Win
方法后台更改header使用http-proxy-middleware代理解决(项目使用vue-cli脚手架搭建)Jqueryjsonp后台更改headerhe
网友问题:使用了vue-cli这个脚手架工具。在开发环境中如何配置跨域这个我懂。但是使用npmrunbuild后,里面所有的ajax的跨域请求url都变成了根目