SpringBoot+Vue3项目跨域配置及Set-Cookie:SameSite=Lax 问题

本文主要是介绍SpringBoot+Vue3项目跨域配置及Set-Cookie:SameSite=Lax 问题,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

SpringBoot+Vue3项目跨域配置及Set-Cookie:SameSite=Lax 问题

背景:项目采用SpringBoot2.x+Vue3。使用axios进行路由跳转访问后端接口时出现 跨域 未携带Cookie 问题。在这里插入图片描述
解决跨域有很多方法,我使用配置后端注解@CrossOrigin来解决跨域问题(此时没有传入任何参数)

添加@CrossOrigin但是没有解决跨域问题

@CrossOrigin
public class UserController {//你的controller内容
}

添加注解后发现跨域问题并没有被解决,发现前端myAxios.ts(axios配置文件)文件中之前配置了withCredentials为true,由于规定withCredentials为true表示允许前端携带凭证,后端origins不能为“ * ” ,而后端origins不配置默认为“ * ” 。故还是会报上面的错误。我这里的解决方法是之间把withCredentials注释掉了。跨域问题解决了。

前端axios发送请求未携带Cookie问题

这个问题就是我刚刚把withCredentials注释掉导致的。axios默认不携带Cookie,需要开启withCredentials:

const myAxios: AxiosInstance = axios.create({withCredentials: true,baseURL: 'http://localhost:8080/api',timeout: 5000000
});

同时后端也要配置origins,来接收凭证:

@CrossOrigin(origins = "http://127.0.0.1:5173/(这里写你的前端地址)", allowCredentials = "true")
public class UserController {//你的controller内容
}

Set-Cookie:SameSite=Lax 问题

在这里插入图片描述
解决方法:Set-Cookie:SameSite=Lax 问题
测试,前后端联调成功,数据请求正常

后端接口返回数据失败(未带Cookie导致),axios无限刷新闪屏

在未携带Cookie的情况下请求后端接口返回数据失败后,我的也面自动刷新,导致了页面无限刷新的情况。这里是我在myAxios.ts中写了如果请求错误,就进行Window Location href,导致页面刷新陷入循环。

最后

Set-Cookie:SameSite=Lax 问题好像只出现了一次,第一次测试成功后,我尝试删除了SessionConfig 配置类,发现也可以正常携带Cookie

这篇关于SpringBoot+Vue3项目跨域配置及Set-Cookie:SameSite=Lax 问题的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/798364

相关文章

kali linux 无法登录root的问题及解决方法

《kalilinux无法登录root的问题及解决方法》:本文主要介绍kalilinux无法登录root的问题及解决方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,... 目录kali linux 无法登录root1、问题描述1.1、本地登录root1.2、ssh远程登录root2、

SQL server配置管理器找不到如何打开它

《SQLserver配置管理器找不到如何打开它》最近遇到了SQLserver配置管理器打不开的问题,尝试在开始菜单栏搜SQLServerManager无果,于是将自己找到的方法总结分享给大家,对SQ... 目录方法一:桌面图标进入方法二:运行窗口进入方法三:查找文件路径方法四:检查 SQL Server 安

SpringMVC获取请求参数的方法

《SpringMVC获取请求参数的方法》:本文主要介绍SpringMVC获取请求参数的方法,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下... 目录1、通过ServletAPI获取2、通过控制器方法的形参获取请求参数3、@RequestParam4、@

SpringBoot应用中出现的Full GC问题的场景与解决

《SpringBoot应用中出现的FullGC问题的场景与解决》这篇文章主要为大家详细介绍了SpringBoot应用中出现的FullGC问题的场景与解决方法,文中的示例代码讲解详细,感兴趣的小伙伴可... 目录Full GC的原理与触发条件原理触发条件对Spring Boot应用的影响示例代码优化建议结论F

springboot项目中常用的工具类和api详解

《springboot项目中常用的工具类和api详解》在SpringBoot项目中,开发者通常会依赖一些工具类和API来简化开发、提高效率,以下是一些常用的工具类及其典型应用场景,涵盖Spring原生... 目录1. Spring Framework 自带工具类(1) StringUtils(2) Coll

Python Transformer 库安装配置及使用方法

《PythonTransformer库安装配置及使用方法》HuggingFaceTransformers是自然语言处理(NLP)领域最流行的开源库之一,支持基于Transformer架构的预训练模... 目录python 中的 Transformer 库及使用方法一、库的概述二、安装与配置三、基础使用:Pi

前端下载文件时如何后端返回的文件流一些常见方法

《前端下载文件时如何后端返回的文件流一些常见方法》:本文主要介绍前端下载文件时如何后端返回的文件流一些常见方法,包括使用Blob和URL.createObjectURL创建下载链接,以及处理带有C... 目录1. 使用 Blob 和 URL.createObjectURL 创建下载链接例子:使用 Blob

Vuex Actions多参数传递的解决方案

《VuexActions多参数传递的解决方案》在Vuex中,actions的设计默认只支持单个参数传递,这有时会限制我们的使用场景,下面我将详细介绍几种处理多参数传递的解决方案,从基础到高级,... 目录一、对象封装法(推荐)二、参数解构法三、柯里化函数法四、Payload 工厂函数五、TypeScript

SpringBoot条件注解核心作用与使用场景详解

《SpringBoot条件注解核心作用与使用场景详解》SpringBoot的条件注解为开发者提供了强大的动态配置能力,理解其原理和适用场景是构建灵活、可扩展应用的关键,本文将系统梳理所有常用的条件注... 目录引言一、条件注解的核心机制二、SpringBoot内置条件注解详解1、@ConditionalOn

通过Spring层面进行事务回滚的实现

《通过Spring层面进行事务回滚的实现》本文主要介绍了通过Spring层面进行事务回滚的实现,包括声明式事务和编程式事务,具有一定的参考价值,感兴趣的可以了解一下... 目录声明式事务回滚:1. 基础注解配置2. 指定回滚异常类型3. ​不回滚特殊场景编程式事务回滚:1. ​使用 TransactionT