在前后端开发过程中一直会伴随我们的问题就是跨域问题,因为这时候前端和后端的代码是在不同机器上运行的,两个地址不在一个域名下,这个时候前端脚本在进行axios访问的时候浏览器就会报跨域相关的错误。
原因:浏览器的同源策略不允许跨域访问,所谓同源策略是指协议、域名、端口相同。
1. 设置代理服务器,实现跨域请求转发
方案:采用proxyTable解决。
-
proxyTable是什么?
vue-cli提供的解决vue开发环境下跨域问题的方法,proxyTable的底层使用了http-proxy-middleware,它是http代理中间件,它依赖node.js,基本原理是用服务端代理解决浏览器跨域
实现的过程就是在我们前端的本地起一个服务,然后我们前端的所有ajax访问首选访问我们本地的服务,本地的服务不会对来的请求做加工处理,只是将请求转发到我们真实的后台服务上去。我们本地的服务其实你就是一个中转站。这种解决方案就是利用后端之间访问是不存在跨域的问题。
-
具体流程
-
首先在
config/index.js
里面找到proxyTable:{}
,然后在里面加入"/api":{ target: 'https://www.runoob.com', changeOrigin: true, pathRewrite:{ '^/api':'' } }
-