前后端分离图片验证码session获取问题

在进行前后端分离项目开发时,遇到验证码Servlet中session值始终为null的问题。通过在AJAX请求中添加特定设置,解决了跨域请求导致的session获取不正确的问题。
摘要由CSDN通过智能技术生成

前后端分离图片验证码session获取问题

最近再搞个项目,在前后端分离时,前端访问验证码Servlet时出现session的值获取总是空的,显示null,如果遇见和我一样的问题可以这样做
这是我写的AJAX

 $.ajax({
   
                    type:"post",
                    url:"跳转Servlet地址",
                    xhrFields:{
   
                        withCredentials:true
                    }
  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
前后端分离的架构验证码的生成和验证应该由后端实现,前端只负责将用户输入的验证码传输到后端进行验证。具体实现步骤如下: 1. 后端生成验证码 后端可以使用Java的UUID类生成唯一的验证码字符串,然后将其保存到Session或者放到Redis等缓存,以便后续验证使用。示例代码如下: ```java String uuid = UUID.randomUUID().toString().replaceAll("-", ""); String verifyCode = VerifyCodeUtil.generateVerifyCode(4); redisTemplate.opsForValue().set(uuid, verifyCode, 5, TimeUnit.MINUTES); // 将验证码保存到缓存,有效期为5分钟 return uuid; ``` 2. 后端将验证码返回给前端 后端可以将生成的验证码(例如uuid)作为响应返回给前端,前端可以将其保存在本地,以便用户在提交表单时一并传输给后端。示例代码如下: ```java @RequestMapping("/code") public String getCode(HttpServletResponse response) throws IOException { String uuid = verifyCodeService.generateVerifyCode(); response.setHeader("Access-Control-Expose-Headers", "uuid"); response.setHeader("uuid", uuid); return null; } ``` 3. 前端展示验证码 前端可以使用图片或者文本的形式展示验证码,用户需要在提交表单时输入正确的验证码。示例代码如下: ```html <img src="/api/code" alt="验证码"> <input type="text" name="verifyCode" placeholder="请输入验证码"> ``` 4. 前端将验证码传输到后端进行验证 用户在提交表单时,前端需要将验证码(例如uuid)和用户输入的验证码一起传输到后端进行验证。后端可以从Session或者缓存获取生成的验证码进行比对,判断用户输入的验证码是否正确。示例代码如下: ```java String uuid = request.getHeader("uuid"); String verifyCode = request.getParameter("verifyCode"); String code = redisTemplate.opsForValue().get(uuid); if (code == null || !verifyCode.equalsIgnoreCase(code)) { return "验证码错误"; } ``` 以上是一个简单的验证码实现过程,具体实现还需要根据自己的业务需求进行调整。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值