龙空技术网

SpringBoot校验手机验证码例:默认缓存、数据淘汰策略、redis缓存

互联网架构小马哥 857

前言:

目前姐妹们对“springboot验证码功能难吗”大致比较关心,同学们都需要分析一些“springboot验证码功能难吗”的相关内容。那么小编同时在网上搜集了一些有关“springboot验证码功能难吗””的相关文章,希望咱们能喜欢,小伙伴们一起来学习一下吧!

目录

本案例实现功能:

1 根据手机号码 生成6位数 的数字 验证码

2 输入手机号和验证码, 判断输入的验证码是否正确

一 默认缓存1.1 主要代码

1 添加依赖

<dependency>			<groupId>org.springframework.boot</groupId>			<artifactId>spring-boot-starter-cache</artifactId>		</dependency>

2 启用缓存

3 实体类

package com.qing.bean;import lombok.Data;@Datapublic class SMSCode {    private String phoneNum;    private String code;}

4 创建验证码的工具类

package com.qing.util;import org.springframework.cache.annotation.Cacheable;import org.springframework.stereotype.Component;@Componentpublic class CodeUtils {    public String generate(String phoneNum) {        int hash = phoneNum.hashCode();        int encryption = 2022630;        //异或加密:一种通过异或运算进行加密的算法        //转成二进制,运算规则:相同为0,不同为1,再转成十进制        long result = hash ^ encryption;        long nowTime = System.currentTimeMillis();        result = result ^ nowTime;        long code = result % 1000000;        //处理有负数的情况        code = code < 0 ? -code : code;        //六位数:前面补0        String.format("%06d",code);        return code + "";    }    //获取缓存里的验证码    @Cacheable(key ="#phoneNum" ,value = "cacheCode")    public String getCacheCode(String phoneNum){        return null;    }}

关于异或运算请点这里

说明:getCacheCode()获取缓存里的验证码的方法,写在工具类这里是因为要使spring的@Cacheable这个注解生效,需要注入spring容器,该工具类在后面的ServiceImpl进行了注入,该方法返回的是注解@Cacheable的value属性值 → cacheCode ( 详见后面的测试 )

5 service

package com.qing.service;import com.qing.bean.SMSCode;public interface SMSCodeService {    //发送验证码    String sendCode(String phoneNum);    //检查验证码    boolean checkCode(SMSCode smsCode);}

6 serviceImpl

package com.qing.service.impl;import com.qing.bean.SMSCode;import com.qing.service.SMSCodeService;import com.qing.util.CodeUtils;import org.springframework.beans.factory.annotation.Autowired;import org.springframework.cache.annotation.CachePut;import org.springframework.stereotype.Service;@Servicepublic class SMSCodeServiceImpl implements SMSCodeService {    @Autowired    CodeUtils codeUtils;    //发送验证码    @Override    //只往里放,不往外读    @CachePut(key = "#phoneNum", value = "cacheCode")    public String sendCode(String phoneNum) {        return codeUtils.generate(phoneNum);    }    //比对验证码    @Override    public boolean checkCode(SMSCode smsCode) {        //取出内存中的验证码与传递过来的验证码比对,相同返回true        String code = smsCode.getCode();        String cacheCode = codeUtils.getCacheCode(smsCode.getPhoneNum());        return code.equals(cacheCode);    }}

7 controller

package com.qing.controller;import com.qing.bean.SMSCode;import com.qing.service.SMSCodeService;import org.springframework.beans.factory.annotation.Autowired;import org.springframework.web.bind.annotation.*;@RestController@RequestMapping("/sms")public class SMSCodeController {    @Autowired    private SMSCodeService smsCodeService;    @GetMapping("/{phoneNum}")    public String getCode(@PathVariable String phoneNum){        return smsCodeService.sendCode(phoneNum);    }    @PostMapping    public boolean checkCode(@RequestBody SMSCode smsCode) {        return smsCodeService.checkCode(smsCode);    }}
1.2 测试

1 生成验证码

2 输入错的验证码验证

3 输入正确的验证码

4 再次生成验证

二 Ehcache缓存

在默认缓存案例的基础上做3个配置就行

1 加依赖

<dependency>            <groupId>net.sf.ehcache</groupId>            <artifactId>ehcache</artifactId>        </dependency>

2 配置文件

3 ehcache.xml放在resources下

默认缓存

配置新的缓存: name 要和@CachePut注解的的value的属性值一样

三 数据淘汰策略

下图表示的信息:

1 下面的时间分别表示最后一次访问是在 第几秒访问的

2 上面的数字表示 访问了几次

LRU:age → 是上次访问离现在的时间最远的

LFU:gender → 访问次数是最少的

四 redis缓存4.1 基础使用

在默认缓存的基础上加2个配置

1 导入依赖

<dependency>     <groupId>org.springframework.boot</groupId>     <artifactId>spring-boot-starter-data-redis</artifactId></dependency>

2 配置文件

测试

打开redis的服务端和客户端

关于redis的安装和简单使用在这里

生成一次验证码

数据已经进到redis缓存里了

缓存的名字即这个value属性的值 和 key 电话号码组合成一个新的key一起放进redis缓存里

再生成一次验证码

redis又多了一个缓存数据

4.2 其他配置测有效时间 10s

看一下测试效果

10s之后缓存里的验证码失效了

备注: 超过了有效时长,redis数据里就没有那个缓存了 ​​​​​​

测前缀

总结

原文

标签: #springboot验证码功能难吗