vue的build先上部署的 devServer不生效的场景记录

文章目录

    • Nginx 相关命令
    • VUE项目devServer.proxy(正向代理)匹配请求中的地址工作流程
      • 开发期间代理proxy的配置
      • 项目打包上线出现的问题描述

Nginx 相关命令

//运行命令
start nginx 启动nginx服务//运行命令
nginx -s stop 停止nginx服务//运行命令
nginx -s reload 重载配置//运行命令
taskkill /f /t /im nginx.exe

VUE项目devServer.proxy(正向代理)匹配请求中的地址工作流程

在本地开发的过程中,为了本地调试方便,通常会在vue.config.js 中配置 devServer。在devServer中配置proxy属性。实现开发期间的轻松跨域请求
目的:可以将指向本地的请求http://localhost:8080/api/action ,代理到后端的开发服务器上http://localhost:8089/personal-management/action

正向代理:代理服务器代替客户端向服务器发起请求。隐藏客户端。
发起请求:代理服务器从客户端发出请求,向目标服务器发起请求。
响应数据:目标服务器响应请求,代理服务器接收请求,并转发给客户端。
注:魔法就是使用的这个原理。

开发期间代理proxy的配置

devServer: { host: 'localhost',//服务器地址port: 8080,webSocketServer: false,proxy: {//配置跨域'/api': {target: 'http://localhost:8089',changeOrigin: true,/** 是否允许跨域 */ws: false,//是否启用websockets,用不到可设为falsepathRewrite: {//对路径匹配到的字符串重写"^/api": "", //请求到 http://localhost:8080/api/user//代理到请求 http://localhost:8089/user },}}} 

当浏览器发起一个请求后, 前端拿配置项中的地址去匹配请求中的地址,如果请求的地址中包含配置中的地址,则匹配成功,匹配成功后,会将匹配到的地址及其后面的地址拼到target的后面,向后端服务器发起跨域请求。

项目打包上线出现的问题描述

最开始将devServer.proxy中的代理地址改成了服务器地址,然后就执行了npm run build打包dist文件,将其部署上线[使用的是Tomcat]。

  • 初始问题是:无法访问到我后端的验证码。

  • 寻找原因:因为在vue.config.js中配置的 devServer.proxy 只是在开发环境下将请求代理到后端服务器的本地服务,我们把项目打包成dist文件只把我们的组件等资源打包了,并不会将代理服务器给打包,所以项目中的请求路径不完整导致访问不到对应资源。我访问的依旧是localhost:8080

怎么解决呢????????

  • 资源要被访问,那必然还是需要有另一个代理来装载它。我们部署上线最常见的就是使用proxy_pass 代理跨域转发! 只需要修改配置文件即可,添加proxy_pass即可,xxx.xxx.xxxx.xxx表示你的服务器地址,8889是我后端的访问端口。
location ^~/api/ {proxy_pass http://xxx.xxx.xxx.xxx:8889/api/;} 

补:2024-4-25

 proxy_cookie_path   /     /api/;    # 解决 nginx 反向代理时 session 丢失 无效

proxy_cookie_path是一个Nginx指令,用于在代理请求时调整Cookie的路径。在你提供的配置中,proxy_cookie_path指令的作用是将请求中的Cookie的路径从根路径"/“修改为”/api"/路径,以便在反向代理时保持session有效。这对解决Nginx反向代理时session丢失的问题很有用。

underscores_in_headers是一个Nginx配置指令,控制Nginx是否允许HTTP请求头中包含下划线。默认情况下,该配置项为off,这意味着Nginx会拒绝这样的请求头,并返回400 Bad Request错误。将其设置为on则允许这样的请求头,但这可能会带来安全风险,因为不是所有服务器都能正确处理这些请求头。

underscores_in_headers on; (默认 underscores_in_headers 为off)

后面单独测试了一下这个,亲测可用

axios.defaults.timeout = 5000 // 请求超时↳
axios.defaults.baseURL = 'http://www.wangzhi.com/'

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/web/3866.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Linux 进程管理快捷键 ctrl+z、ctrl+c、ctrl+\、ctrl+d介绍

在Linux系统中,可以使用一些特定的键盘快捷键来管理后台进程和控制终端的行为。下面是对这些快捷键的介绍: 1 CtrlZ(挂起): 在终端中运行程序时,你可以使用CtrlZ来将其挂起,即将其移动到后台并…

zabbix图形乱码解决方案

zabbix使用中文后,图形那里乱码,因为没有中文包,需要安装中文包并且应用 1.安装中文包 yum install -y wqy-microhei-fonts 2.修改配置 /usr/share/zabbix/include/defines.inc.php 修改为 define(ZBX_GRAPH_FONT_NAME, wqy-microhei); 3…

Pytorch:张量的梯度计算

目录 一、自动微分简单介绍1、基本原理2、梯度计算过程3、示例:基于 PyTorch 的自动微分a.示例详解b.梯度计算过程c.可视化计算图 4、总结 二、为什么要计算损失,为何权重更新是对的?1、梯度下降数学原理2、梯度上升 三、在模型中使用自动微分…

时间延迟嵌入定理 Time-Delay Embedding Theorem 以及C++实现例子

时间延迟嵌入定理(Time-Delay Embedding Theorem),也称为Takens嵌入定理,由荷兰数学家Floris Takens在1981年提出。这个定理在动力系统理论中非常重要,特别是在从实验数据重建动力系统的状态空间模型方面具有广泛应用。…

js箭头函数的this

结论 箭头函数没有自己的this箭头函数的this取决于父级的作用域箭头函数的this在函数定义的时候就已经确定了,但是普通函数的this是在运行的时候才能确定的,因为要看是谁调用它的;所以箭头函数的this不会受到调用方式的影响,是静…

【U+】U+智享版运维平台账号密码重置

【问题描述】 友加畅捷系列中的U智享版软件, 系统运维平台账号admin密码忘记了,无法登录。 【解决方法】 在软件的安装目录下,找到sysconfig_accounts文件,并删除。 【路径:X:\U系列软件\U智享版\WebSite\config\】 …

【ZZULIOJ】1082: 敲7(多实例测试)(Java)

目录 题目描述 输入 输出 样例输入 Copy 样例输出 Copy code 题目描述 输出7和7的倍数,还有包含7的数字例如(17,27,37...70,71,72,73...) 输入 首先输入一个整数t&#xff…

制造业企业做图纸的怎么才能做好cad加密,什么cad加密软件最好?

众所周知,通常CAD图纸中包含着大量的设计数据和产品信息,所以无论对于CAD设计工程师,还是对于企业,如何保障CAD图纸信息数据安全都是十分重要的。 很多企业通过购买第三方安全软件来加密保护CAD设计图纸,但第三方安全软…

【算法基础实验】图论-UnionFind连通性检测之quick-union

Union-Find连通性检测之quick-union 理论基础 在图论和计算机科学中,Union-Find 或并查集是一种用于处理一组元素分成的多个不相交集合(即连通分量)的情况,并能快速回答这组元素中任意两个元素是否在同一集合中的问题。Union-Fi…

AI技术宝库:一键收藏全球最全面的人工智能资源网站

1、KKAI(kk.zlrxjh.top) R5AI是一种融合了星火大模型与文心大模型的知识增强型大语言模型,主要聚焦于自然语言处理(NLP)的技术开发。 该模型具有卓越的语义理解和文本生成能力,可以有效处理多种复杂的自然语…

python爬虫-----深入了解 requests 库下篇(第二十六天)

🎈🎈作者主页: 喔的嘛呀🎈🎈 🎈🎈所属专栏:python爬虫学习🎈🎈 ✨✨谢谢大家捧场,祝屏幕前的小伙伴们每天都有好运相伴左右,一定要天天…

M-LAG的基本概念

如图所示,用户侧设备Switch(可以是交换机或主机)通过M-LAG机制与另外两台设备(SwitchA和SwitchB)进行跨设备链路聚合,共同组成一个双活系统。这样可以实现SwitchA和SwitchB共同进行流量转发的功能&#xff…

MySQL查出时间比实际晚8小时的解决方案

查询出来的日期数据比数据库中日期数据晚8小时,一开始很懵逼,IDEA 和 server 时区都一样呢!后来发现: jdbcUrljdbc:mysql://localhost:hentai?useUnicodetrue&characterEncodingUTF-8&useJDBCCompliantTimezoneShifttru…

C++11单例模式

🐶博主主页:ᰔᩚ. 一怀明月ꦿ ❤️‍🔥专栏系列:线性代数,C初学者入门训练,题解C,C的使用文章,「初学」C,linux 🔥座右铭:“不要等到什么都没有了…

16(第十五章,数据管理成熟度评估)

目录 概述 数据管理成熟度等级 基本概念 评级等级以及特点 现有的DMMA框架 活动 方法 扩展 概述 数据管理成熟度等级 1) 0 级。无能力级。2) 1 级。初始级或临时级:成功取决于个人的能力。3) 2 级。可重复级:制定了最初级的流程规则。4) 3 级。…

【webrtc】m114自己实现的PrioritizedPacketQueue及优先级处理

G:\CDN\WEBRTC-DEV\libwebrtc_build\src\modules\pacing\prioritized_packet_queue.h跟m98不同 :webrtc】m98 RoundRobinPacketQueue的优先级处理,m114直接使用taskqueue顺序处理了。甚至自己实现了优先级队列感觉简化了实现,更为清晰 易读,但是去掉了码率低就优先的逻辑。1…

C 语言实例 - 两个浮点数相乘

输入两个浮点数&#xff0c;计算乘积。 #include <stdio.h>int main() {float num1, num2, product;printf("请输入第一个浮点数: ");scanf("%f", &num1);printf("请输入第二个浮点数: ");scanf("%f", &num2);product …

企业计算机服务器中了rmallox勒索病毒怎么办?Rmallox勒索病毒解密流程工具

在网络飞速发展的时代&#xff0c;企业离不开网络&#xff0c;网络为企业的生产运营提供了极大便利&#xff0c;加快了企业进步的步伐&#xff0c;依靠网络可以开展各项工作业务&#xff0c;通过网络数据整合&#xff0c;可以更方便企业办公。网络在为企业提供便利的同时也为企…

ESLint 、 e2e test 学习

Lint和Format的区别&#xff1a; Lint只会告诉你代码中的错误或者不符合规范的地方&#xff0c;而Format是用来对格式作调整的 HTML/tpl&#xff1a;HTMLLint CSS/SCSS&#xff1a;Stylelint JS/JSX&#xff1a;Eslint JSLint&#xff1a;古老&#xff0c;不能配置和扩展JSHin…

【C++类和对象】日期类的实现

&#x1f49e;&#x1f49e; 前言 hello hello~ &#xff0c;这里是大耳朵土土垚~&#x1f496;&#x1f496; &#xff0c;欢迎大家点赞&#x1f973;&#x1f973;关注&#x1f4a5;&#x1f4a5;收藏&#x1f339;&#x1f339;&#x1f339; &#x1f4a5;个人主页&#x…