0

0

vue-cli 代理请求原理

WBOY

WBOY

发布时间:2023-05-25 09:51:07

|

599人浏览过

|

来源于php中文网

原创

vue 是一个流行的 javascript 框架,它可以用来创建交互式的 web 应用程序。在开发过程中,我们通常会用到 vue-cli 来初始化一个基本的 vue 项目。 vue-cli 是 vue 官方提供的一个脚手架工具,它提供了许多方便的功能,例如项目初始化、打包、发布等。

但是,在开发过程中我们可能会遇到一个问题:跨域请求。由于浏览器的同源策略,当我们在前端 Ajax 发送请求时,只能请求同一域名下的服务器资源,而不能请求其他域名的服务器资源。这个时候,我们可以通过 vue-cli 中的代理请求来解决这个问题。

那么,vue-cli 中的代理请求是如何实现的呢?

直接请求和代理请求的区别

在了解代理请求的原理之前,我们需要了解一下直接请求和代理请求之间的区别。当我们在开发过程中直接通过 Ajax 请求访问后台服务时,请求会直接从前端发往后端,如下图所示:

直接请求示意图

立即学习前端免费学习笔记(深入)”;

这种方式会涉及到跨域问题。如果后端接口没有设置跨域响应头,那么浏览器就会禁止前端发起 AJAX 请求,从而导致请求失败。

而在 vue-cli 中,我们会通过代理请求来解决这个问题。代理请求的基本思路是,将请求发送到本地服务器,然后由本地服务器将请求转发至后端服务器。

代理请求示意图

vue.config.js 中的代理配置

在 vue-cli 项目中,我们可以通过配置 vue.config.js 文件来设置代理请求。在该文件中,我们可以设置 devServer 选项,通过设置 proxy 对象进行代理配置。下面是一个简单的例子:

module.exports = {
  devServer: {
    proxy: {
      '/api': {
        target: 'http://localhost:8080',
        changeOrigin: true
      }
    }
  }
}

在上述代理配置中,我们将 /api 路径下的请求都转发到本地的 http://localhost:8080 地址。

企站帮微商城系统Access版
企站帮微商城系统Access版

OdnShop(原企站帮微商城系统,更名为OdnShop),基于ASP.NET 4.0+Access开发的轻量级微信商城系统,前台简洁美观,后台容易操作。系统容易部署,空间成本低,大部分的几百块一年的虚拟主机均可支持(具体请咨询空间商),适合要求不高,预算不多的小商店,小企业初次尝试微信线上销售产品,目前基本的核心功能,包括微信登陆/支付,产品管理,购物车与订单管理,分享获取积分,积分礼品兑换功能

下载

其中, changeOrigin 选项用于控制是否需要更改请求头中原始主机名。

proxy 对象中,我们可以设置多个代理地址,例如:

module.exports = {
  devServer: {
    proxy: {
      '/api1': {
        target: 'http://localhost:8081',
        changeOrigin: true
      },
      '/api2': {
        target: 'http://localhost:8082',
        changeOrigin: true
      }
    }
  }
}

这里的 /api1/api2 分别代表要转发的请求路径, target 属性指定了要转发到的服务器地址。

实现原理

在了解了代理请求的配置后,我们来看一下代理请求的实现原理。

首先,当我们在前端发起请求时,请求会先被发送到本地服务器。本地服务器接收到请求后,会对请求进行一系列处理,包括修改请求头、修改请求路径等。然后,将处理过的请求转发至后端服务器上。

流程图如下:

代理请求流程图

需要注意的是,在本地服务器中,我们需要设置代理中间件,例如 http-proxy-middleware。代理中间件是一个类似于响应请求的拦截器,用于控制请求过程并修改请求内容。我们可以通过配置代理中间件来实现请求的代理转发。

总结

通过上述的介绍,我们了解了 vue-cli 中的代理请求原理。代理请求是一种在前端解决跨域问题的方法,通过将请求转发至本地服务器,再由本地服务器将请求转发至后端服务器,达到跨域请求的效果。在 vue-cli 中,我们可以通过配置 vue.config.js 文件来设置代理请求,从而实现前端的跨域请求。

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

相关专题

更多
云朵浏览器入口合集
云朵浏览器入口合集

本专题整合了云朵浏览器入口合集,阅读专题下面的文章了解更多详细地址。

20

2026.01.20

Java JVM 原理与性能调优实战
Java JVM 原理与性能调优实战

本专题系统讲解 Java 虚拟机(JVM)的核心工作原理与性能调优方法,包括 JVM 内存结构、对象创建与回收流程、垃圾回收器(Serial、CMS、G1、ZGC)对比分析、常见内存泄漏与性能瓶颈排查,以及 JVM 参数调优与监控工具(jstat、jmap、jvisualvm)的实战使用。通过真实案例,帮助学习者掌握 Java 应用在生产环境中的性能分析与优化能力。

29

2026.01.20

PS使用蒙版相关教程
PS使用蒙版相关教程

本专题整合了ps使用蒙版相关教程,阅读专题下面的文章了解更多详细内容。

162

2026.01.19

java用途介绍
java用途介绍

本专题整合了java用途功能相关介绍,阅读专题下面的文章了解更多详细内容。

120

2026.01.19

java输出数组相关教程
java输出数组相关教程

本专题整合了java输出数组相关教程,阅读专题下面的文章了解更多详细内容。

41

2026.01.19

java接口相关教程
java接口相关教程

本专题整合了java接口相关内容,阅读专题下面的文章了解更多详细内容。

10

2026.01.19

xml格式相关教程
xml格式相关教程

本专题整合了xml格式相关教程汇总,阅读专题下面的文章了解更多详细内容。

14

2026.01.19

PHP WebSocket 实时通信开发
PHP WebSocket 实时通信开发

本专题系统讲解 PHP 在实时通信与长连接场景中的应用实践,涵盖 WebSocket 协议原理、服务端连接管理、消息推送机制、心跳检测、断线重连以及与前端的实时交互实现。通过聊天系统、实时通知等案例,帮助开发者掌握 使用 PHP 构建实时通信与推送服务的完整开发流程,适用于即时消息与高互动性应用场景。

23

2026.01.19

微信聊天记录删除恢复导出教程汇总
微信聊天记录删除恢复导出教程汇总

本专题整合了微信聊天记录相关教程大全,阅读专题下面的文章了解更多详细内容。

172

2026.01.18

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号