Vue proxyTable配置多个接口地址,解决跨域的问题


Posted in Javascript onSeptember 11, 2020

最开始的时候,因为请求后台出现跨域问题。

查找资料配置proxyTable,解决跨域问题。如下图所示:

Vue proxyTable配置多个接口地址,解决跨域的问题

axios请求页面:

this.$axios.post('/api/weblogin/login',data).then(res=>{
    console.log(res)
})

后面遇到需要连接不同的接口域名,我在proxyTable里增加了一个apiGas。axios请求存在获取得到api但是不能获取apiGas(提示请求资源不存在)。

proxyTable: {
   '/api': {
    target: 'http://', // 接口域名
    changeOrigin: true, //是否跨域
    pathRewrite: {
     '^/api': '/bsgzf/api/auth/' , //需要rewrite的,
    },
   },
   '/apiGas': {
    target: 'http://', // 接口域名
    changeOrigin: true, //是否跨域
    pathRewrite: {
     '^/apiGas':'/bsgzf/api/gas/'
    }
   },  
  },

查找了很多资料都没有具体的解决方法,偶然在一个相同的问题下发现一个回复,让把这两个链接位置换一下,抱着试一试的态度换了,重新运行,结果两个都可以获取了。不知道什么原理???有知道的请指教!!!

正解:

proxyTable: {
   '/apiGas': {
    target: 'http://', // 接口域名
    changeOrigin: true, //是否跨域
    pathRewrite: {
     '^/apiGas':'/bsgzf/api/gas/'
    }
   }, 
   '/api': {
    target: 'http://', // 接口域名
    changeOrigin: true, //是否跨域
    pathRewrite: {
     '^/api': '/bsgzf/api/auth/' , //需要rewrite的,
    },
   }, 
  },

补充知识:Vue里的proxyTable解决跨域,api接口管理

本文单纯的介绍Vue项目中接口的集中管理以及跨域的解决方法。

1.webpack里的proxyTable设置跨域:config->index.js

module.exports = {
 dev: {
  assetsSubDirectory: 'static',
  assetsPublicPath: '/',
  proxyTable: {
   '/api':{
    target:'http://localhost:80', //这里配置的是 请求接口的域名
    // secure: false, // 如果是https接口,需要配置这个参数
    changeOrigin: true, // 如果接口跨域,需要进行这个参数配置
    pathRewrite:{
     '^/api':'' //路径重写,这里理解成用'/api'代替target里面的地址.
    }
   }
  },
 }

2.设置api

2.1文件目录

Vue proxyTable配置多个接口地址,解决跨域的问题

2.2 api.js 编码

import axios from 'axios'

axios.defaults.baseURL = '/api';
axios.defaults.headers.post['Content-Type'] = 'application/json;charset=utf-8';
axios.defaults.withCredentials = true

//接口自定义

//修改用户信息接口
export const updateOneUser = params => {
 return axios.post('/anta/anta-back/src/php/updateUser.php', params)
  .then(res => res.data)
};

3.组件中引用

import {updateOneUser} from "../../api/api"
methods:{
  //给后台发送数据
  var params = new URLSearchParams();
  params.append('userphone', this.watchStudentInfo.userphone);
  params.append('userpass', this.watchStudentInfo.userpass);
  console.log(params)
  updateOneUser(params).then(data=>{
   //后台返回的数据
   if(data==1){
    //添加成功
    this.$message.success('修改成功')
   }else{
    //失败
    this.$message.success('修改失败')
   }
  }).catch(error=>{
   this.$message.success('修改失败')
  })
}

以上这篇Vue proxyTable配置多个接口地址,解决跨域的问题就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
jQuery.Validate 使用笔记(jQuery Validation范例 )
Jun 25 Javascript
基于jQuery的前端数据通用验证库
Aug 08 Javascript
JavaScript建立一个语法高亮输入框实现思路
Feb 26 Javascript
jQuery 获取/设置/删除DOM元素的属性以a元素为例
May 23 Javascript
JavaScript定时显示广告代码分享
Mar 02 Javascript
JavaScript实现彩虹文字效果的方法
Apr 16 Javascript
Js实现无刷新删除内容
Apr 29 Javascript
基于Vue、Vuex、Vue-router实现的购物商城(原生切换动画)效果
Jan 09 Javascript
浅谈mvvm-simple双向绑定简单实现
Apr 18 Javascript
详解Vue中watch的详细用法
Nov 28 Javascript
JS浏览器BOM常见操作实例详解
Apr 27 Javascript
关于React Native 无法链接模拟器的问题
Jun 21 Javascript
关于ES6尾调用优化的使用
Sep 11 #Javascript
在js文件中引入(调用)另一个js文件的三种方法
Sep 11 #Javascript
Vue项目开发常见问题和解决方案总结
Sep 11 #Javascript
JavaScript实现简单日历效果
Sep 11 #Javascript
vue $mount 和 el的区别说明
Sep 11 #Javascript
JavaScript 判断数据类型的4种方法
Sep 11 #Javascript
jQuery实现日历效果
Sep 11 #jQuery
You might like
php添加文章时生成静态HTML文章的实现代码
2013/02/17 PHP
PHP多进程编程实例
2014/10/15 PHP
php生成图片验证码
2015/06/09 PHP
深入解析PHP的Yii框架中的缓存功能
2016/03/29 PHP
html中的input标签的checked属性jquery判断代码
2012/09/19 Javascript
onbeforeunload与onunload事件异同点总结
2013/06/24 Javascript
jQuery UI 实现email输入提示实例
2013/08/15 Javascript
JavaScript中读取和保存文件实例
2014/05/08 Javascript
javascript多行字符串的简单实现方式
2015/05/04 Javascript
实例讲解避免javascript冲突的方法
2016/01/03 Javascript
浅谈js中的延迟执行和定时执行
2016/05/31 Javascript
js插件Jcrop自定义截取图片功能
2016/10/14 Javascript
Bootstrap基本插件学习笔记之折叠(22)
2016/12/08 Javascript
Vue 2.0在IE11中打开项目页面空白的问题解决
2017/07/16 Javascript
关于定制FileField中的上传文件名称问题
2017/08/22 Javascript
利用nginx + node在阿里云部署https的步骤详解
2017/12/19 Javascript
微信小程序实现登录遮罩效果
2018/11/01 Javascript
Vue 子组件与数据传递问题及注意事项
2019/07/11 Javascript
vue日历/日程提醒/html5本地缓存功能
2019/09/02 Javascript
原生JavaScript实现日历功能代码实例(无引用Jq)
2019/09/23 Javascript
Vue解析剪切板图片并实现发送功能
2020/02/04 Javascript
vue利用全局导航守卫作登录后跳转到未登录前指定页面的实例代码
2020/05/19 Javascript
[49:12]完美世界DOTA2联赛PWL S2 Magma vs GXR 第二场 11.29
2020/12/02 DOTA
python查找第k小元素代码分享
2013/12/18 Python
Python实现二叉堆
2016/02/03 Python
在pycharm下设置自己的个性模版方法
2019/07/15 Python
详解python itertools功能
2020/02/07 Python
Python TKinter如何自动关闭主窗口
2020/02/26 Python
Python-split()函数实例用法讲解
2020/12/18 Python
国贸专业的职业规划书
2014/03/15 职场文书
2014年档案管理工作总结
2014/11/17 职场文书
2015暑假社会调查报告
2015/07/13 职场文书
入党申请书格式
2019/06/20 职场文书
JavaScript中MutationObServer监听DOM元素详情
2021/11/27 Javascript
docker 制作mysql镜像并自动安装
2022/05/20 Servers
码云(gitee)通过git自动同步到阿里云服务器
2022/12/24 Servers