详解vue-cli3 中跨域解决方案


Posted in Javascript onApril 10, 2019

此方案只能用于开发环境,线上最好设置同源策略(遇到个后端,装你妈批)

前后端不在同一服务器的情况下,前端要访问后端API,可通过在vue.config.js中配置代理服务器。

0:前提条件

1:安装vue-lic

2:安装axios  用于发送请求。

1:将任何未知请求转发到代理服务器

如:

前端地址:127.0.0.1

后端地址:127.0.0.2

当访问地址为 127.0.0.1/api,没有匹配到这地址,那么就会被转发到代理服务器127.0.0.2/api

module.exports={
  devServer:{
    proxy: "http://www.acfun.cn"
  }
}

2:多代理控制

更多代理服务配置项搜索http-proxy-middleware查看

module.exports = {
  devServer: {
    proxy: {
      '/search': {  // search为转发路径
        target: 'http://www.acfun.cn', // 目标地址
        ws: true, // 是否代理websockets
        changeOrigin: true  // 设置同源 默认false,是否需要改变原始主机头为目标URL,        
      }
    }
  }
};

如:

当前访问地址为  xxx.xxx.xxx/search时,就会被转发到代理服务器http://www.acfun.cn/search

xxx.xxx.xxx/search -> http://www.acfun.cn/search

 3:实例

api.js 文件(主要用于全局配置)

import Axios from "axios";

let http = Axios.create({
  timeout: 3000,  //超时配置 3秒
  responseType: 'json',  // 响应数据格式
  responseEncoding: 'utf8', // 响应数据编码
});

export default http;

入口文件  main.js

import Vue from "vue";
import App from "./App.vue";
import router from "./router";
import http from "./api";  // 引用axios全局配置

Vue.config.productionTip = false;

Vue.prototype.$http = http;  // 添加原型方法,这样创建的对象就自带该方法了。

new Vue({
  router,
  render: h => h(App)
}).$mount("#app");

vue.config.js 配置文件

更多代理服务配置项搜索http-proxy-middleware查看

module.exports = {
  devServer: {
    proxy: {
      '/search': {
        target: 'http://www.acfun.cn',
        ws: true,//是否代理websockets
        changeOrigin: true  // 设置同源 默认false,是否需要改变原始主机头为目标URL
      }
    }
  }
};

总结

以上所述是小编给大家介绍的vue-cli3 中跨域解决方案,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
CSS+JS构建的图片查看器
Jul 22 Javascript
checkbox全选/取消全选以及checkbox遍历jQuery实现代码
Dec 02 Javascript
javascript中的注释使用与注意事项小结
Sep 20 Javascript
疯狂Jquery第一天(Jquery学习笔记)
May 11 Javascript
Jjcarousellite 实现图片列表滚动的简单实例
Nov 29 Javascript
js为空或不是对象问题的快速解决方法
Dec 11 Javascript
js的window.showModalDialog及window.open用法实例分析
Jan 29 Javascript
element-ui中的select下拉列表设置默认值方法
Aug 24 Javascript
js实现无缝滚动双图切换效果
Jul 09 Javascript
layui的表单验证支持ajax判断用户名是否重复的实例
Sep 06 Javascript
微信小程序加载机制及运行机制图解
Nov 27 Javascript
vuex实现购物车的增加减少移除
Jun 28 Javascript
js中数组常用方法总结(推荐)
Apr 09 #Javascript
JS隐藏号码中间4位代码实例
Apr 09 #Javascript
vue 点击展开显示更多(点击收起部分隐藏)
Apr 09 #Javascript
详解axios中封装使用、拦截特定请求、判断所有请求加载完毕)
Apr 09 #Javascript
关于vue状态过渡transition不起作用的原因解决
Apr 09 #Javascript
vue实现文字横向无缝走马灯组件效果的实例代码
Apr 09 #Javascript
Angular脚手架开发的实现步骤
Apr 09 #Javascript
You might like
UTF8编码内的繁简转换的PHP类
2009/07/09 PHP
PHP中利用substr_replace将指定两位置之间的字符替换为*号
2011/01/27 PHP
php中设置index.php文件为只读的方法
2013/02/06 PHP
PHP SOCKET编程详解
2015/05/22 PHP
Yii2增加验证码步骤详解
2016/04/25 PHP
PHP中PDO连接数据库中各种DNS设置方法小结
2016/05/13 PHP
PHP构造函数与析构函数用法示例
2016/09/28 PHP
a标签的css样式四个状态
2021/03/09 HTML / CSS
放弃用你的InnerHTML来输出HTML吧 jQuery Tmpl不详细讲解
2013/04/20 Javascript
JavaScript的setAttribute兼容性问题解决方法
2013/11/11 Javascript
nodejs读取memcache示例分享
2014/01/02 NodeJs
javascript设置连续两次点击按钮时间间隔的方法
2014/10/28 Javascript
Winform客户端向web地址传参接收参数的方法
2016/05/17 Javascript
鼠标经过出现气泡框的简单实例
2017/03/17 Javascript
socket.io实现在线群聊功能
2017/04/07 Javascript
JavaScript设计模式之单例模式详解
2017/06/09 Javascript
JavaScript异步上传图片文件的实例代码
2017/07/04 Javascript
Angular实现的自定义模糊查询、排序及三角箭头标注功能示例
2017/12/28 Javascript
在vue项目中引入高德地图及其UI组件的方法
2018/09/04 Javascript
JS实现利用闭包判断Dom元素和滚动条的方向示例
2019/08/26 Javascript
python端口扫描系统实现方法
2014/11/19 Python
python使用chardet判断字符串编码的方法
2015/03/13 Python
Python过滤列表用法实例分析
2016/04/29 Python
Python文件的读写和异常代码示例
2017/10/31 Python
python timestamp和datetime之间转换详解
2017/12/11 Python
python Matplotlib模块的使用
2020/09/16 Python
利用HTML5的新特点实现图片文件异步上传
2014/05/29 HTML / CSS
解析html5 canvas实现背景鼠标连线动态效果代码
2019/06/17 HTML / CSS
Antler英国官网:购买安特丽行李箱、拉杆箱
2019/08/25 全球购物
投标邀请书范文
2014/01/31 职场文书
买卖协议书范本
2014/04/21 职场文书
初中作文评语大全
2014/04/23 职场文书
思想作风纪律整顿心得体会
2014/09/04 职场文书
买卖合同协议书范本
2014/10/18 职场文书
2016年精神文明建设先进个人事迹材料
2016/02/29 职场文书
Python内置的数据类型及使用方法
2022/04/13 Python