Axios的使用和跨域问题的解决

AXIOS的使用方法

1、下载

apache_conf
npm install axios -s

2、 导入

import axios from 'axios'//引入axios
Vue.prototype.$axios = axios;//把axios挂载到vue上

3、使用

  this.$axios({
                method:"post",
                url:"/login",
                data:{
                    form:this.ruleForm
                }
              }).then(function (resp){
                    console.log("请求成功",resp)
              }).catch(function(err){
                    console.log("请求失败",err)
              })
          }

解决跨域问题

在本地项目中,后端使用的是SpringBoot 开启127.0.0.1:80端口

在前端,Vue使用的是127.0.0.1:8080端口

在前端使用axios发送ajax请求时,因为端口的不同产生了跨域。

1.解决方法有两种
2.后端允许跨域请求(SpringBoot一个注解就可以解决)前端代理请求。

这里记录一下前端代理请求,解决跨域问题的步骤:

1.导入axios之后,设置前缀

import axios from 'axios';
//设置前缀,任何使用到axios发送请求的地方,目标url都会加上这个前缀
axios.defaults.baseURL = '/api';

2.配置config/index.js文件,在proxyTable对象中添加‘/api’对象

 // Paths
    assetsSubDirectory: 'static',
    assetsPublicPath: '/',
    proxyTable: {
      
      '/api': {
              target:'http://localhost:80/', // 你请求的第三方接口
              changeOrigin:true, // 在本地会创建一个虚拟服务端,然后发送请求的数据,并同时接收请求的数据,这样服务端和服务端进行数据的交互就不会有跨域问题
              ws: true,
              pathRewrite:{  // 路径重写,
                '^/api': ''  // 替换axios 请求url中的地址,也就是说^/api=/target,请求target这个地址的时候直接写成/api即可。
              }
            }
    },

3.需要注意的地方是,请求时,url中不要写ip和端口号

this.$axios({
                method:"post",
                url:"/login",//这里不要带前面的ip和端口号

总结

1.没有设置代理前我的请求是http://127.0.0.1:8080/login端口(前端Vue的地址是8080端口)
2.设置完axios.defaults.baseURL = '/api';请求变成了http://127.0.0.1:8080/api/login(请求失败,因为没有对应的接口)
3.设置config/index.js配置文件之后,代理会把^/api(^表任意) 替换成/target(proxytable设置的target项)
也就是http://127.0.0.1:8080/api/loginhttp://127.0.0.1:8080/api/变成了http://localhost:80/
代理之后的请求地址变成了http://localhost:80/login


版权声明:本文为qq_19286785原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。