Vue3 + Spring WebMVC 验证码案例中的跨域问题与解决方法

embedded/2025/2/26 18:04:23/

               

        最近在基于vue3 + SpringWebMVC前后端分离的开发环境中实现一个验证码的案例,在开发过程中遇到了一些复杂的跨域问题,现已解决,故将解决方法分享,希望能帮到有需要的人。

        出现的问题:

        对于验证码的实现,我选择引入第三方Jar包,在开发至验证码校验时,此时正常逻辑为:前端向后端请求验证码图片,后端返回验证码图片并设置cookie,将正确验证码存储至session中;当用户提交验证码后,前端会发送ajax请求携带用户输入信息给后端,后端根据请求所携带的cookie从session中获取正确验证码与用户输入进行比对,然后返回校验结果。

        在实际开发中,前端请求验证码图片时,后端返回了图片并设置了cookie,但在提交验证码时,请求未携带cookie,导致后端无法从session中获取正确的验证码。

        问题原因分析:


        我在进行代码排查时,发现校验请求所设置的session存在如下提示,即:set-cookie没有指定SameSite属性,默认为Lax。

        SameSite是cookie中的一个属性,用于控制cookie在跨站请求时的发送策略,其属性值存在三个,如下:
        SameSite=Strict:最为严格,cookie仅在相同站点进行发送

        SameSite=Lax:相对宽松,在跨站顶级导航且请求方法为GET时也会发送cookie,但对于跨站请求(表单提交、ajax请求)则不会发送cookie

        SameSite=None:最为宽松,允许cookie在跨站请求中发送,但是必须同时设置Secure属性为true,即只能通过Https协议传输

        在此处,由于SameSite默认为Lax,浏览器会自动阻断cookie传输,这就导致了请求时未携带cookie

        解决方案:        


        1,配置跨域访问

        后端:可以在控制器上使用@CrossOrigin注解,也可以通过实现WebMvcConfigurer接口的addCorsMappings方法来全局配置跨域,我使用的是注解的方式。需要注意的是,注解中的allowCredentials属性必须设置为true,表示允许接收cookie

@CrossOrigin(origins = "允许访问的域名", allowCredentials = "true")

         前端:我使用的是axios模块发送ajax请求,设置如下:

  // 全局配置,允许携带cookieaxios.defaults.withCredentials = true
        2,修改 SameSite属性

        后端将cookie SameSite属性修改为None,使其允许跨域访问;而当我们将SameSite属性修改为None时,secure属性必须设置为true;这样做是为了允许cookie在跨域请求时发送,并确保cookie只能通过Https传输,增强安全性。

import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.session.web.http.CookieSerializer;
import org.springframework.session.web.http.DefaultCookieSerializer;@Configuration
public class CookieConfig {@Beanpublic CookieSerializer cookieSerializer() {DefaultCookieSerializer serializer = new DefaultCookieSerializer();// 设置cookie名称serializer.setCookieName("JSESSIONID");// 设置cookie地址serializer.setCookiePath("/");// 设置 HttpOnly属性serializer.setUseHttpOnlyCookie(true);// 设置Secure属性(仅Https)serializer.setUseSecureCookie(true); // 设置 SameSite属性为Noneserializer.setSameSite("None"); return serializer;}
}
        3,启用Https

        secure属性为true,即仅允许https传输,故我们还需要将前后端服务网络协议更换为https。只需为前后端添加证书,启用https协议即可

        后端:使用keytool工具生成自签名证书,将其放在并在src/main/resource目录下,并在application.yml中配置Https

server:port: 8443ssl:key-store: classpath: 证书文件名称.p12key-store-password: 证书密码key-store-type: PKCS12key-alias: tomcat

        前端:使用openssl生成自签名证书,并在vite.config.js中配置Https

import { defineConfig } from 'vite'export default defineConfig({server: {https: {key: "xxx/key.pem",cert: "xxx/cert.pem"}}
})

        注意事项: 

  •         SameSite=None 和 Secure=true 必须同时使用
  •         在生产环境中建议使用正式的SSL证书,而不是自签名证书
  •         上述配置完毕后均需重启服务生效

        


http://www.ppmy.cn/embedded/167325.html

相关文章

JavaScript web APIs第一天——04-code——06-随机抽奖案例.html

文章目录 JavaScript web APIs第一天——04-code——06-随机抽奖案例.html JavaScript web APIs第一天——04-code——06-随机抽奖案例.html <!DOCTYPE html> <html lang"en"><head><meta charset"UTF-8" /><meta http-equiv&…

Kubernetes集群状态检查与告警整合的自动化

将Kubernetes集群状态检查与告警整合的自动化方案&#xff0c;包含脚本实现、定时任务配置及异常通知机制&#xff1a; 1. 创建监控脚本 保存为 /opt/k8s-monitor/cluster-check.sh&#xff1a; #!/bin/bash# 基础配置 LOG_DIR"/var/log/k8s-monitor" REPORT_FILE&…

游戏引擎学习第120天

仓库:https://gitee.com/mrxiao_com/2d_game_3 上次回顾&#xff1a;周期计数代码 我们正在进行一个项目的代码优化工作&#xff0c;目标是提高性能。当前正在优化某个特定的代码片段&#xff0c;已经将其执行周期减少到48个周期。为了实现这一目标&#xff0c;我们设计了一个…

C++对象模型之C++额外成本

1.介绍 C与C最大的区别&#xff0c;无疑在于面向对象&#xff0c;面向对象编程给C带来了强大的特性和灵活性。但同时也带来了一定的运行时和编译时的开销。下面介绍C对象模型的额外成本及其来源。 2.C的额外成本 &#xff08;1&#xff09;虚函数和动态多态的成本 虚函数表&am…

ESP32移植Openharmony外设篇(8)MQ-3酒精检测传感器

MQ-3酒精检测 模块简介 应用场景 MQ3是MQ传感器系列中最常用的传感器之一。它是金属氧化物半导体&#xff08;MOS&#xff09;类型的传感器。金属氧化物传感器也被称为化学电阻在暴露于醇&#xff0c;因为感测基于所述感测材料的电阻的变化。因此&#xff0c;通过将其放置在…

v4l2子系统学习(五)subdev和media子系统

文章目录 1、声明2、subdev和media子系统2.1、subdev的引入2.2、media子系统的引入2.3、subdev概览和数据结构2.3.1、实例2.3.2、数据结构 2.4、media子系统概览和数据结构2.4.1、拓扑结构2.4.2、数据结构2.4.3、media子系统和subdev的关系 2.5、subdev的注册和使用2.5.1、内核…

Docker Engine stopped

参考【已解决】win10系统 Docker 提示Docker Engine stopped解决全过程记录-CSDN博客 关键的处理办法&#xff1a;需要wsl --update更新一下&#xff0c;然后卸载docker&#xff0c;重新安装后重启系统恢复正常 重启系统后看到running状态

选择排序:简单高效的选择

大家好&#xff0c;今天我们来聊聊选择排序&#xff08;Selection Sort&#xff09;算法。这是一个非常简单的排序算法&#xff0c;适合用来学习排序的基本思路和操作。选择排序在许多排序算法中以其直观和易于实现的特点著称&#xff0c;虽然它的效率不如其他高效算法&#xf…