基于VUE3+VITE+SpringBoot+Nginx部署项目之跨域配置等问题

前言:遇到问题,解决问题。

第一部分:VUE 配置

1、vite.config.js 文件

server: {proxy: {'/api': {target: env.VITE_BASE_URL,changeOrigin: true,secure: false,rewrite: path => path.replace(/^\/api/, '')}}},

2、.env 文件

VITE_BASE_URL = 'https://api.xxx.cn'

3、axios 文件

const instance = axios.create({baseURL: '/api',timeout: 10000,
});

4、某接口文件

 const login = async (params) => {return requestInstancePostFormData('/user/login', params);};
二、Spring Boot 配置

1、某接口文件

@CrossOrigin
@RestController
@RequestMapping("/user")
@Api(tags = "User API")
public class UserController {......
}

2、文件配置

 String[] apiExcludes = new String[]{"/user/login",};registration.excludePathPatterns(apiExcludes);
三、Nginx 配置
root /www/wwwroot/www.xxx.cn/dist;#Nginx 配置可以确保 Vue Router 正常工作location / {try_files $uri $uri/ @router;index index.html;}location @router {rewrite ^.*$ /index.html last;}#反向代理配置,确保后面有/location /api {proxy_pass https://api.xxx.cn/;}

至此,基本完成,不过有个特别地方,请注意:登录时会报401,如下图:

解决如下图:

两者区别分析(以下分析来自chatGPT):

在 Nginx 的配置中,proxy_pass 指令用于指定反向代理的目标服务器:

  1. proxy_pass https://api.xxx.cn;

    • 这种写法没有在结尾处加斜杠 (/)。
    • Nginx 将会把匹配到的请求路径直接拼接在 https://api.xxx.cn 后面。例如,如果请求的路径是 /api/user/login,Nginx 将会将它转发到 https://api.xxx.cn/api/user/login
  2. proxy_pass https://api.xxx.cn/;

    • 这种写法在结尾处加了斜杠 (/)。
    • Nginx 将会忽略掉请求路径中匹配的 location 配置部分,仅将域名后面的路径直接替换成请求路径。例如,如果请求的路径是 /api/user/login,Nginx 将会将它转发到 https://api.xxx.cn/user/login,即忽略了 location 中定义的 /api 部分。

总结区别:

  • 无斜杠 (proxy_pass https://api.xxx.cn;):保留匹配到的 location 中的路径部分,并将其附加在代理目标的URL后面。
  • 有斜杠 (proxy_pass https://api.xxx.cn/;):忽略匹配到的 location 中的路径部分,直接将请求路径附加在代理目标的URL后面。

至此,结文。

鸣谢:chatGPT 陪伴产品开发的每一天。

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

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

相关文章

springcloud-config 客户端启用服务发现client的情况下使用metadata中的username和password

为了让spring admin 能正确获取到 spring config的actuator的信息,在eureka的metadata中添加了metadata.user.user metadata.user.password eureka.instance.metadata-map.user.name${spring.security.user.name} eureka.instance.metadata-map.user.password${spr…

气象相关图表制作-字体图标、图片、折线的堆叠

开发工作中有个需要展示气温(折线)、天气(图片)、风羽(字体图标)的图表展示需求,之前用过highcharts的关于类似的chart,里面的风雨用的是自带的图片,但是现在要求风羽需要…

Windows环境本地部署开源在线演示文稿应用PPTist并实现远程访问

💝💝💝欢迎来到我的博客,很高兴能够在这里和您见面!希望您在这里可以感受到一份轻松愉快的氛围,不仅可以获得有趣的内容和知识,也可以畅所欲言、分享您的想法和见解。 推荐:kwan 的首页,持续学…

Elasticsearch exists 和 missing 查询:检查字段是否存在或缺失

在Elasticsearch中,数据通常以文档的形式存储,而每个文档又包含多个字段。在查询数据时,我们经常需要知道某个字段是否存在或者是否缺失。为了满足这种需求,Elasticsearch提供了exists和missing查询,它们允许我们基于字…

Linux双网卡默认路由的metric设置不正确,导致SSH连接失败问题定位

测试环境 VMware虚拟机 RockyLinux 9 x86_64 双网卡:eth0(访问外网): 10.206.216.92/24; eth1(访问内网) 192.168.1.4/24 问题描述 虚拟机重启后,SSH连接失败,提示"Connection time out",重启之前SSH连接还是正常的…

基础指标 派生指标 计算指标 这些指标的区别是什么?

基础指标、派生指标、计算指标这些指标的区别是什么? 基础指标、派生指标和计算指标在数据分析和业务度量中各自扮演着不同的角色,它们之间的区别主要体现在定义、构建方式和用途上。 基础指标(基础指标/原子指标): …

基于Spring Boot医护人员排班系统

设计技术: 开发语言:Java数据库:MySQL技术:SpringbootMybatisvue 工具:IDEA、Maven、Navicat 主要功能: 医护类型管理 医护人员排班系统的系统管理员可以对医护类型添加修改删除以及查询操作。具体界面…

SS8870T-3.6A 扫地机和滚刷电机的大电流电机驱动

扫地机器人已经成为现代家庭清洁的必备工具,而其中的关键部件——电机,对于其性能和用户体验起着至关重要的作用。为了确保扫地机器人的高效清洁和稳定运行,至少需要使用7个直流电机,包括行走轮、滚轮、边刷和吸尘等功能的驱动。 …

Python接口测试课程,每天学会一个Python小知识!

第一天: Python基础 Python简介、环境搭建及包管理 Python简介: 特点:Python是一门动态、解释型、强类型语言 动态:在运行期间才做数据检查(不用提前声明变量)- 静态语音(C/Java):编译时检查数据类型&…

根据指定日期自定义el-date-picker日期选择器样式

需求 功能需要在DatePicker日期选择器中,对有数据的日期下方添加小圆点提示样式,后台会返回按年份查询的日期数据 dayjs插件 dayjs中文网:https://dayjs.fenxianglu.cn/ npm install dayjs实现点 配置picker-options对象中的cellClassName属性…

django 逆向生成对应数据库表的models模型类 —— python

一,在setting.py中配置好连接数据库的参数 在setting中的DATABASESZ中配置默认参数,并在INSTALLED_APPS中导入模块名。 DATABASES {default:{ENGINE: django.db.backends.mysql, # 数据库引擎NAME: jljupcs, # 数据库名称HOST: 127.0.0.1, # 数据库…

亚马逊商品详情的 API 接口获取与分析:挖掘商业价值的关键技术

在当今竞争激烈的电商领域,获取和分析准确的商品详情信息对于企业和开发者来说至关重要。亚马逊作为全球领先的电商平台,其丰富的商品资源和庞大的用户群体为商业决策提供了极具价值的数据。通过 API 接口获取亚马逊商品详情并进行深入分析,已…

检索增强生成RAG系列1--RAG的实现

大模型出现涌现能力之后,针对大模型的应用也如雨后春笋般。但是,在大模型真正落地之前,其实还需要做好最后一公里,而这个最后一公里,其中不同应用有着不同的方法。其中prompt、微调和RAG都是其中方法之一。本系列就是针…

网络协议 -- IP、ICMP、TCP、UDP字段解析

网络协议报文解析及工具使用介绍 1. 以太网帧格式及各字段作用 -------------------------------- | Destination MAC Address (48 bits) | -------------------------------- | Source MAC Address (48 bits) …

JVM 知识总结

是什么 JVM是Java Virtual Machine(Java虚拟机)的缩写,是通过在实际的计算机上仿真模拟各种计算机功能来实现的。由一套字节码指令集、一组寄存器、一个栈、一个垃圾回收堆和一个存储方法域等组成。JVM屏蔽了与操作系统平台相关的信息&#…

介绍Java反射的基本原理和安全措施

一、Java反射的基本原理 Java反射(Reflection)是Java语言的一个特性,它允许程序在运行时对自身进行检查,并且能够操作类、接口、字段和方法等。反射提供了强大的功能,但也带来了一定的技术难点。 基本原理&#xff1…

简单的同步压缩变换脊线检测(PythonMATLAB)

由于 Heisenberg 测不准原理,线性时频变换方法无法同时在时间和频率方向达到最佳的时频分布,窗函数和小波函数的选择也降低了各方法的自适应性。同样,二次型变换方法难以在去除交叉干扰项的同时保证较高的能量集中度。为了解决该问题&#xf…

MySQL的安装与配置

MySQL提供安装包和压缩包两种安装方式,安装包是以.msi作为后缀名的二进制分发文件,压缩包是以.zip为后缀的压缩文件。安装包的安装只要双击安装文件,然后按照提示一步步安装就可以了,属于“傻瓜”式安装;压缩包的安装需…

vivo手机 创建不了文件夹 因为文件夹名字用了关键字!

/storage/emulated/0/Android/data/com.luming.xsxparent/files/learningmachine/voice/1719475869218voice.amr: open failed: ENOENT (No such file or directory) 最终发现是因为创建的文件夹名字叫voice ,估计和系统冲突了不让创建,记录下

基于SpringBoot校园一卡通系统设计和实现(源码+LW+调试文档+讲解等)

💗博主介绍:✌全网粉丝10W,CSDN作者、博客专家、全栈领域优质创作者,博客之星、平台优质作者、专注于Java、小程序技术领域和毕业项目实战✌💗 Java精品实战案例《600套》 2023-2025年最值得选择的Java毕业设计选题大全&#xff1…