vue 设置proxyTable参数进行代理跨域

2022-01-13,,,,

这篇文章主要介绍了vue 设置proxyTable参数进行代理跨域的相关资料,及代理跨域的概念原理,需要的朋友可以参考下

什么是代理跨域

浏览器之间有同源策略,出于安全考虑不同域之间不允许获取数据,除了几个特殊的例子

、、等标签可以进行跨域但是通常都是以get的形式,如果用js的axios去远程获取的话进会触发同源政策,除非你服务端的代码设置了header同意让你访问,明显这很不合理呀!。现在不是都流行前后端的分离吗,后端代码跑掉了只剩下前端了,两个次元的代码我前端该怎么获取啊,感觉使用跨域好麻烦好难搞啊还不一定搞得到,这个时候就可以用到代理跨域了

代理跨域原理

所谓代理就是代替前端而是用后端发出http请求,就如vue的脚手架中,要运行项目你要输入npm run dev或npm run start吧,这个命令其实打开它已经配置好的node服务器,vue脚手架的代理就是通过node来代替前台发起http请求,既然不是浏览器发起的请求那不是就很容易啦?

vue脚手架如何代理跨域,找到在config文件夹下的index.js文件,文件中有个dev,在里面找到proxyTable{},对它进行修改

 proxyTable: { '/api': { target: 'https://www.xxx.com/',//你要跨的域 changeOrigin: true, pathRewrite: { '^/api': '/api', }, headers:{ //这边可以堆headers进行设置 } }, },

其中target是你要跨域的地址,/api是你所跨的域下的下一级路径,像上面这样就是获取https://www.xxx.com/api下的东西,然后我们引入一个ajax的包axios并进行ajax

 import axios from 'axios' axios.get('/getMessage').then(()=>{})

上面的代码执行后,会自动帮你跨域获取到https://www.xxx.com/api/getMessage的数据

总结

以上所述是小编给大家介绍的vue 设置proxyTable参数进行代理跨域,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对本站网站的支持!

您可能感兴趣的文章:

  • 详解vue-cli项目开发/生产环境代理实现跨域请求
  • vue-cli 3.x配置跨域代理的实现方法
  • vue-cli 3.x 配置Axios(proxyTable)跨域代理方法
  • vue打包使用Nginx代理解决跨域问题
  • vue代理和跨域问题的解决
  • vue.js使用代理和使用Nginx来解决跨域的问题
  • 详解Vue-cli代理解决跨域问题
  • 详解vue-cli本地环境API代理设置和解决跨域
  • vue使用代理解决请求跨域问题详解

以上就是vue 设置proxyTable参数进行代理跨域的详细内容,更多请关注本站其它相关文章!

《vue 设置proxyTable参数进行代理跨域.doc》

下载本文的Word格式文档,以方便收藏与打印。