Vue 配置代理

news/2024/7/10 2:23:15 标签: vue

文章目录

  • 方式一
  • 方式二
  • vue 脚手架配置代理总结

方式一

首先安装 axios:npm i axios

修改 App.vue

<template>
  <div>
    <button @click="getBookInfo">获取书籍信息</button>
  </div>
</template>

<script>
import axios from "axios"
export default {
  name: 'App',
  methods:{
    getBookInfo(){
      axios.get("http://localhost:8080/downloads/data.json").then(
          response =>{
            console.log("请求成功了",response.data);
          },
          error => {"请求失败了",error.message}
      )
    }
  }
}
</script>

点击按钮请求书籍的信息,其中http://localhost:8080/downloads/data.json返回了书籍信息:
在这里插入图片描述
当我们点击按钮时,却发现报错了:
在这里插入图片描述
这是跨域请求的错误,当协议名(http)、主机名(localhost)、端口号(8080) 中有一个不一致会提示跨域请求。解决办法有:1、cors;2、jsonp;3、代理服务器

我们来学习第三个,可以先查看下官方文档 Vue Cli 配置参考:devServer.proxy

流程:8081 向 8080 请求数据,我们开启一个代理服务器,端口号和我们的 8081 相同

修改
1、 vue.config.js,直接复制官网代码,修改端口号为请求数据的端口8080

const { defineConfig } = require('@vue/cli-service')
module.exports = defineConfig({
  transpileDependencies: true,
  lintOnSave:false,
  //开启代理服务器
  devServer: {
    proxy: 'http://localhost:8080'
  }
})

2、请求数据端口修改为本地端口 8081
在这里插入图片描述
3、由于修改了脚手架配置,所以先停掉端口,然后重新运行
在这里插入图片描述
可以看到请求成功了
在这里插入图片描述

方式二

方式一有两个不完美的地方:1、只能配置一个代理服务器。2、当本地也就是 public 中有相同数据,就不请求代理服务器了

1、修改 vue.config.js,注释掉方式一的代码,改为

devServer: {
    proxy: {
      '/api': {
        target: 'http://localhost:8080',
        pathRewrite:{'^/api':''},
        ws: true,
        changeOrigin: true
      }
    }
  }

其中/api为请求前缀,可以改成其他名字
pathRewrite为路径重写,匹配api开头的字符串,并把api替换为空字符串,这样才能保证代理服务器转发给 8080 的不带前边的前缀
ws 用于支持websocket
changeOrigin请求来自于。即控制请求头中host数据。默认为true说谎:来自8080;false如实回答来自代理服务器8081

2、请求路径增加前缀
在这里插入图片描述
3、由于修改了脚手架配置,所以先停掉端口,然后重新运行

vue__84">vue 脚手架配置代理总结

方法一
vue.config.js中添加如下配置:

devServer: {
    proxy: 'http://localhost:8080'
}

说明:
1.优点:配置简单,请求资源时直接发给前端(8080)即可。
2.缺点:不能配置多个代理,不能灵活的控制请求是否走代理
3.工作方式:若按照上述配置代理,当请求了前端不存在的资源时,那么该请求会转发给服务器(优先匹配前端资源)

方法二

devServer: {
    proxy: {
      '/api': {//匹配所有以/api开头的路径
        target: 'http://localhost:8080',//代理目标的基础路径
        pathRewrite:{'^/api':''},//路径重写,匹配api开头的字符串,并把api替换为空字符串
        ws: true,//用于支持websocket
        changeOrigin: true//请求来自于。即控制请求头中host数据。默认为true说谎:来自8080;false如实回答来自代理服务器8081
      }
    }
  }

说明:
1.优点:可以配置多个代理,且可以灵活的控制请求是否走代理。
2.缺点:配置略微繁琐,请求资源时必须加前缀。


http://www.niftyadmin.cn/n/1816727.html

相关文章

JS中的继承方式总结

1. 原型链继承(又称类继承) Child.prototype new Parent(); 1 function Parent (name, age) {2 this.name name;3 this.age age;4 }5 Parent.prototype.say function(){6 console.log(hello, my name is this.name);7 };8 function Child() {9 } 10 Child.p…

回发或回调参数无效。在配置中使用 或在页面中使用 启用了事件验证。

回发或回调参数无效。在配置中使用 <pages enableEventValidation"true"/> 或在页面中使用 <% Page EnableEventValidation"true" %> 启用了事件验证。出于安全目的&#xff0c;此功能验证回发或回调事件的参数是否来源于最初呈现这些事件的服…

Vue github用户搜索案例

文章目录完成样式请求数据完善使用 vue-resource完成样式 1、public 下新建 css 文件夹&#xff0c;放入下载好的 bootstrap.css&#xff0c;并在 index.html 中引入 2、新建 Search.vue <template><section class"jumbotron"><h3 class"jumbo…

js 常用排序整理

排序&#xff1a;   1. 内部排序&#xff1a;     (1). 交换排序&#xff1a;       1). 冒泡排序 稳定         一次比较相邻两个元素的大小&#xff0c;顺序错误的&#xff0c;将其位置互换         &#xff08;从高位到低位 或者 从低位到高位…

学习WPF: 创建数据绑定目录树

如果使用了WPF而不使用数据绑定(手工在界面和数据间进行同步),总会感觉不值.但是大部分讨论WPF数据绑定的文章,主题大多集中在ListBox这样平坦的数据集合上,讲如何绑定层次结构数据的比较少,这里我就通过一个简单的显示磁盘目录树的例子来展示如何完成这样的任务.第一步,当然是…

Vue 插槽的使用

文章目录默认插槽具名插槽作用域插槽插槽总结$slot默认插槽 首先做一个页面&#xff1a; 新增 Category.vue <template> <div class"category"><h3>{{title}}分类</h3><ul><li v-for"(item,index) in listData" :key…

XSL学习笔记

http://www.cnsdn.com.cn/blog/article.asp?id702摘要&#xff1a;xsl:templatexsl:value-ofxsl:for-eachxsl:sortxsl:ifxsl:choosexsl:whenxsl:otherwisexsl:apply-templatesxsl:importxsl:includexsl:apply-importsxsl:attributexsl:attribute-setxsl:paramxsl:call-templat…

angularJS 单页面 两个及以上个 ng-app 的处理方式

1 <div ng-app"myApp1" ng-controller"myCtrl1">2 3 名: <input type"text" ng-model"firstName"><br>4 姓: <input type"text" ng-model"lastName"><br>5 <br>…