详解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 相关文章推荐
JavaScript传递变量: 值传递?引用传递?
Feb 22 Javascript
使用apply方法处理数组的三个技巧[译]
Sep 20 Javascript
JavaScript中的this关键字介绍与使用实例
Jun 21 Javascript
javascript获取form里的表单元素的示例代码
Feb 14 Javascript
使用JavaScript脚本无法直接改变Asp.net中Checkbox控件的Enable属性的解决方法
Sep 16 Javascript
jquery实现手机端单店铺购物车结算删除功能
Feb 22 Javascript
JS基于正则实现数字千分位用逗号分隔的方法
Jun 16 Javascript
Vue项目webpack打包部署到服务器的实例详解
Jul 17 Javascript
关于angularJs清除浏览器缓存的方法
Nov 28 Javascript
区别JavaScript函数声明与变量声明
Sep 12 Javascript
vue从一个页面跳转到另一个页面并携带参数的解决方法
Aug 12 Javascript
Vue+element-ui添加自定义右键菜单的方法示例
Dec 08 Vue.js
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
比特率,大家看看这个就不用收音机音质去比MP3音质了
2021/03/01 无线电
php防注
2007/01/15 PHP
PHP 输出缓存详解
2009/06/20 PHP
php获取当月最后一天函数分享
2015/02/02 PHP
全新Mac配置PHP开发环境教程
2016/02/03 PHP
Zend Framework教程之模型Model基本规则和使用方法
2016/03/04 PHP
php实现的读取CSV文件函数示例
2017/02/07 PHP
laravel5.6 框架操作数据 Eloquent ORM用法示例
2020/01/26 PHP
js数组的操作详解
2013/03/27 Javascript
jquery监听div内容的变化具体实现思路
2013/11/04 Javascript
JavaScript定义类的几种方式总结
2014/01/06 Javascript
Node.js中HTTP模块与事件模块详解
2014/11/14 Javascript
JS实现在网页中弹出一个输入框的方法
2015/03/03 Javascript
使用console进行性能测试
2015/04/27 Javascript
Vuejs第十篇之vuejs父子组件通信
2016/09/06 Javascript
详解ES6之async+await 同步/异步方案
2017/09/19 Javascript
微信自定义分享链接信息(标题,图片和内容)实现过程详解
2019/09/04 Javascript
[01:25]DOTA2超级联赛专访iG 将调整状态找回自己
2013/06/05 DOTA
[56:13]DOTA2-DPC中国联赛定级赛 LBZS vs Phoenix BO3第一场 1月10日
2021/03/11 DOTA
Python爬虫抓取手机APP的传输数据
2016/01/22 Python
python读取和保存图片5种方法对比
2018/09/12 Python
Python sorted排序方法如何实现
2020/03/31 Python
Python 如何实现访问者模式
2020/07/28 Python
CSS3制作酷炫的三维相册效果
2016/07/01 HTML / CSS
kfc实习自我鉴定
2013/12/14 职场文书
学期自我评价
2014/01/27 职场文书
原料仓管员岗位职责
2014/04/12 职场文书
节约用电标语
2014/06/17 职场文书
人身损害赔偿协议书范本
2014/09/27 职场文书
审计局2014法制宣传日活动总结
2014/11/01 职场文书
2016元旦文艺汇演主持词
2015/07/06 职场文书
2015年卫生院健康教育工作总结
2015/07/24 职场文书
银行客户经理培训心得体会
2016/01/09 职场文书
详解GaussDB for MySQL性能优化
2021/05/18 MySQL
Vue Element-ui表单校验规则实现
2021/07/09 Vue.js
MutationObserver在页面水印实现起到的作用详解
2022/07/07 Javascript