Axios(四):跨域请求

在前后端开发过程中一直会伴随我们的问题就是跨域问题,因为这时候前端和后端的代码是在不同机器上运行的,两个地址不在一个域名下,这个时候前端脚本在进行axios访问的时候浏览器就会报跨域相关的错误。

原因:浏览器的同源策略不允许跨域访问,所谓同源策略是指协议、域名、端口相同。

前端跨域

思路: 设置代理服务器,实现跨域请求转发

方案:采用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':''
    }
}

注意:

  • /api: 是自定义的,写成什么都可以。

  • target: 设置要调用的接口域名和端口号。

  • ^/api: 代替target里面的地址,后面组件中我们调接口时直接用/api代替

在组件中实现跨域请求

比如要访问'https://www.runoob.com/ajax/json_demo.json',直接写/api/ajax/json_demo.json即可。

import axios from 'axios'

axios.get('/api/ajax/json_demo.json')
    .then(resp=>{
        console.log(resp.data)
    })
    .cath(err=>{
        console.log(err)
    })

自定义axios请求基础路径

然而我们可以在src/main.js设置一个基础路径,这样你调用接口的时候可以不写api,直接写/ajax/json_demo.json即可。

src/main.js设置axios.defaults.baseURL="/api";

import axios from 'axios'
axios.defaults.baseURL="/api";

在组件中直接调用接口即可。

import axios from 'axios'

axios.get('/ajax/json_demo.json')
    .then(resp=>{
        console.log(resp.data)
    })
    .cath(err=>{
        console.log(err)
    })

后端跨域

但是今天我们这里不讲这种方式,有兴趣的可以在我的另一篇博客看到