• 使用vue init webpack 你的项目名称初始化一个vue的项目
  • 安装依赖 npm install vue-resource http-proxy-middleware vuex koa
  • 在项目的main.js中引入并注册下载的依赖
    • 在main.js中引入vue-resource并注册到vue实例中
import VueResource from 'vue-resource'  //用来请求接口
Vue.use(VueResource)
//开启后请求就会以application/x-www-form-urlencoded作为MIME type 就像普通的html表单一样,form形式传给后台,而非JSON
Vue.http.options.emulateJSON = true;
  • 在main.js文件同级创建一个store的文件夹用来存放vuex的文件
  • 在store文件夹中创建一个index.js的文件(vue在查找时会自动查找这个文件),在文件中创建store实例并导出
   import Vue from 'vue'
import VueX from 'vuex'
import actions from './actions' //这里为了可扩展性,所以单独创建一个文件用来存放请求方法 Vue.use(VueX);
//请求之甬道actions所以只导入了actions
export default new VueX.Store({
actions
});
  • 在store文件夹中创建一个actions.js的文件用来存放请求方法

  • 配置请求代理

    • 在config文件夹下面创建一个host.js文件用来存放开发、测试、生产的请求地址ip

    • 在文件中你可以根据条件来配置到底是开发还是测试或者是正式环境
    • let HostType = 0;  //用来判断当前是什么环境
      let Host = {}; //用来存储当前环境的请求ip
      if (HostType == 0) {
      Host = { //对象内的字段可以自定义如果整个项目只有一个后台地址只需要一个字段就可以;
      api: "127.0.0.1:9000",
      base: "",
      fileUp: ""
      }
      } else if (HostType == 1) {
      Host = {
      ...
      }
      } else if (HostType == 2) {
      Host = {
      ...
      }
      }
      module.exports = Host;
    • 在config文件夹下面创建一个proxy-table.js文件用来存放代理的配置
      const HOST = require("./HOST.js");
      
      module.exports = {
      //接口代理
      "/api/text": {
      target: HOST.api, //需要代理到那个地址
      changeOrigin: true //是否跨域
      },
      "/api/demo": {
      target: HOST.api,
      changeOrigin: true
      }
      }
    • 在config文件夹下面创建一个proxy-middleware.js凭借代理和注册
      //导入插件
      const proxyMiddleware = require("http-proxy-middleware");
      //导入代理的配置
      const proxyTable = require("./proxy-table");
      //拿出配置代理的所有匹配的字段
      const proxyContext = Object.keys(proxyTable); // ["/api/text","/api/demo"] module.exports = () => {
      //创建一个默认的配置对象
      const defautOptions = {
      changeOrigin: true,
      secure: false
      }
      //为什么return的是一个async的方法是因为请求代理是通过服务器进行代理的在启动脚本中会使用koa框架来注册这个中间件
      return async (ctx, next) => { //ctx和next都是koa框架中间件自带的参数
      for (let context of proxyContext) { //循环我们拿到的keys数组
      if (ctx.url.startsWith(context)) { //判断当前请求的url中是不是以拿到的keys数组中的某个值开头的
      ctx.respond = false; //绕开koa框架的内置response处理
      let options = proxyTable[context];
      //如果拿取到的直接是IP地址就赋值给配置对象
      if (typeof options === 'string') {
      options = {
      target: options
      }
      }
      //使用Object.assign()方法合并两个对象
      options = Object.assign({},defautOptions,options);
      //将每一个代理都注册,这里必须return一个自执行函数否则代理不会设置成功
      proxyMiddleware(context,options)(ctx.req,ctx.res, next);
      }
      }
      await next();
      }
      }
    • 在项目的更目录中创建一个服务启动的文件脚本名字自定义
    • //在脚本文件中导入我们需要的框架和代理配置文件
      const Koa = require("koa"); //所用的框架
      const proxy = require("./config/proxy-middleware"); //刚才创建的代理配置文件
      //创建一个服务
      const app = new Koa(); //将代理插件注册到服务上
      app.use(proxy()); //因为我们导出的是一个方法所以需要使用调用的方式注册 //启动服务
      app.listen(9000,() => {
      console.log("server running at http://127.0.0.1:9000");
      }); //对koa框架不是熟悉的可以使用express框架 如果使用express框架拿代理就不用使用前面那样复杂的写法了
      const express = require("express");
      const proxy = require("http-proxy-middleware"); const app = express(); app.use(express.static("dist/"));
      app.use("/all", proxy({
      target: "http://127.0.0.1:3000",
      changeOrigin: true,
      })) app.listen(9000, (err) => {
      if (err) return console.log(err);
      console.log("app as running at http://127.0.0.1:9000");
      })
    • 代理配置好以后就可以写请求方法了,在创建好的store文件夹下面的actions文件里编写请方法
    • //导入Vue
      import Vue from "vue"
      export default {
      //测试接口
      testInterface({},postdata) {
      //postdata是你调用的时候传过来的参数可以更具需求拼接接口
      //let ipstr = `/api/text?id=${postdata.id}`;
      //return Vue.http.get(ipstr,{}).then(response => {
      return Vue.http.get("/api/text",{}).then(response => {
      if (response.status == 200) {
      return new Promise(response.body);
      } else {
      return new Promise(response.data.message);
      }
      })
      }
      }
    • 测试代理是否成功
    • <div id="app">
      <button @click="clickF">按钮</button>
      </div>
    • 首先在script标签里面将vuex导入进来
    • import {mapActions} from "vuex";
    • 在methods中创建一个方法用来发送请求,并在methods的最下面使用结构函数将我们存在vuex中的请求方法按需导入
    • methods: {
      clickF() {
      this.testInterface().then(data=> {
      console.log(data);
      })
      },
      ...mapActions(["testInterface"])
      }
    • 直接使用this.方法名就可以访问到vuex中的actions方法;这里使用的是辅助函数,也可以使用原始方法
    • 在终端中使用node 启动脚本文件的名称 或者使用 nodemon 启动脚本文件的名称
    • 在浏览器中打开服务的地址点击我们创建的按钮查看请求接口
    • 可以看到我们的代理是请求成功的;状态之所以是304是因为第二次请求的时候如果请求没有发生改变就会使用浏览器缓存;
    • 上面遗留了一个bug就是这个方法只适用于build后的项目;在开发中每次都build无疑浪费了很多时间,下面就来在开发环境中使用服务器代理的方式完成跨域请求
    • 如果是cli创建的项目直接在config文件夹下面的index文件中的proxyTable进行添加就可以了

      

Vue使用vue-recoure + http-proxy-middleware + vuex配合promise实现基本的跨域请求封装的更多相关文章

  1. Spring Boot + Vue 跨域请求问题

    使用Spring Boot + Vue 做前后端分离项目搭建,实现登录时,出现跨域请求 Access to XMLHttpRequest at 'http://localhost/open/login ...

  2. vue实现跨域请求的设置

    vue实现跨域请求,需要在vue.config.js里添加以下设置 proxy: { '/service/rest': { target: 'http://localhost:8080/autotab ...

  3. 本地Vue项目跨域请求本地Node.js服务器的配置方法

    前言:跨域请求是在本地开发时经常遇到的需求,也很简单,只是几句代码配置一下的问题.我初次配置跨域请求时由于官方的说明太简洁,找到的教程又落伍,调试了一番并没有解决问题,到最后解决问题,已花费了很多时间 ...

  4. vue 使用axios 跨域请求数据的问题

    axios默认是没有jsonp 跨域请求的方法的.一般来说流行的做法是将跨域放在后台来解决,也就是后台开发人员添加跨域头信息. 例如java中的 header,response.setHeader(& ...

  5. $Django 前后端之 跨域问题(同源策略) vue项目(axios跨域请求数据)

    1 跨域问题(多个域之间的数据访问) #同源策略(ip port 协议全部相同) #本站的只能请求本站域名的数据 #CORS实现(跨域资源共享) #实现CORS通信的关键是服务器.只要服务器实现了CO ...

  6. VUE系列三:实现跨域请求(fetch/axios/proxytable)

    1. 在 config/index.js 配置文件中配置proxyTable 'use strict' // Template version: 1.3.1 // see http://vuejs-t ...

  7. vue.js学习之 跨域请求代理与axios传参

    vue.js学习之 跨域请求代理与axios传参 一:跨域请求代理 1:打开config/index.js module.exports{ dev: { } } 在这里面找到proxyTable{}, ...

  8. Vue ajax跨域请求

    Vue webpack-dev-server实现跨域请求 思路 配置webpack-dev-server,代理某一个路径到目标路径,同是更改源和重写 Vue里定义一个全部变量:site Vue.pro ...

  9. Vue三步完成跨域请求

    三步完成跨域请求 ①main.js中: Vue.prototype.HOME = '/api'; ② config/index.js中: module.exports = { dev: { // Pa ...

随机推荐

  1. ReentrantReadWriteLock总结

    ReentrantReadWriteLock的流程的一些特性: // ReentrantReadWriteLock.WriteLock.lock()特性: • 已持有读锁的线程不能再持有写锁: • 已 ...

  2. CLR中你想知道的事

    CLR是什么? CLR 公共语言运行时,是一个可由多个语言共同使用的运行环境,核心(内存管理,程序集加载,安全性,异常处理和多线程) Visual Studio是一种编译器,编译器也可称为语法检查器和 ...

  3. Quartz技术原理

    Quartz运行基本: (1)       创建任务jobDetail(放入具体的jobImpl),触发器trigger(保存job的触发策略),均放入调度器scheduler. (2)       ...

  4. Spring Boot 面试题总结

    1.什么是spring boot 答案:springboot是用来简化spring应用的初始搭建和开发过程,使用特定的配置文件来配置,例如application.properties,简化来maven ...

  5. 第五场周赛(字符串卡常个人Rank赛)——题解

    本次题目因为比较简单,除了个别题目,其余题目我只写一个思路不再贴代码. 先是Div.2的题解 A题奇怪的优化,把递归函数改成2*fun(...)即可,其实看懂程序也不难,就是求a*2b: B题你会st ...

  6. Day 18 软件管理3之搭建网络仓库

    搭建一个网络仓库 服务端: 10.0.0.200   1.准备软件包( 1.光盘 2.缓存 3.联网下载 4.同步 ) 2.通过p共享软件包存放的目录 3.将光盘中的软件包都拷贝至p的共享目录下 4. ...

  7. [python]python的异常处理

    异常处理:首先了解异常,程序出现逻辑错误或者用户输入不合法都会引发异常,而这些异常并不是致命的所以不会导致程序崩溃死掉.可以利用Python提供的异常处理机制在异常出现时及时捕获,并从内部自我消化. ...

  8. 程序员写 2000 行 if else?领导:这个锅我不背

    前言 知乎上有小伙伴提了这么一个问题,如何看待陕西省普通话水平测试成绩查询系统?查询系统前端代码就直接给出了身份账号,姓名,证书编号,如果信息是真的,就泄露了这么多考生的信息,白给那种.为什么会发生这 ...

  9. Spring 梳理 - ContentNegotiatingViewResolver

    ContentNegotiatingViewResolver,这个视图解析器允许你用同样的内容数据来呈现不同的view.它支持如下面描述的三种方式: 1)使用扩展名http://localhost:8 ...

  10. Maven 梳理-手动创建Maven项目(非web),使用Maven编译、测试、打包、安装、引用

    创建空目录 F:\jtDevelop\maventest\myapp 创建pom.xml文件 <project xmlns="http://maven.apache.org/POM/4 ...