Kaptcha生成图片验证码

先看结果图。

思路:

        ①进入登录页的时候,前端通过Axios发送GET请求,获取验证码。

        ②后端收到请求后,生成验证码code和该验证码对应的关键字codeKey。

        ③将codeKey和code作为Key,Value保存在Redis中,设置有效期一分钟。

        ④后端将验证码变为图片格式并转换为Base64编码,和codeKey封装成Map返回给前端,前端解析。

        ⑤用户登录时,输入账号、密码和验证码,前端添加上codeKey一并返回给后端,后端拿着codeKey在Redis中查询对应的验证码,判断验证码是否存在,是否正确等,验证码校验不通过返回前端对应报错信息。验证码通过在进行账号密码校验。

        这是基本思路,其次关键代码如下所示。(注意:RedisUtils和ResultUtils文中并未给出,需根据个人习惯编写。)

一、引入Maven依赖

<dependency>
      <groupId>com.github.penggle</groupId>
      <artifactId>kaptcha</artifactId>
      <version>2.3.2</version>
</dependency>

 二、编写Kaptcha工具类

import javax.annotation.Resource;
import javax.imageio.ImageIO;
import java.awt.image.BufferedImage;
import java.io.ByteArrayOutputStream;
import java.io.IOException;
import java.util.Base64;
import java.util.HashMap;
import java.util.Map;
import java.util.UUID;

/**
 * @ClassName: KaptchaUtils
 * @Description: 生成验证码图片
 * @author: 阿长
 * @date: 2022/12/9 17:27
 */
public class KaptchaUtils {

    @Resource
    private DefaultKaptcha producer;
    @Resource
    private RedisUtils redisUtils;

    public ResultUtils getCode() throws IOException {
        // 生成文字验证码
        String code = producer.createText();
        System.out.println("code:" + code);
        // 生成图片验证码
        ByteArrayOutputStream outputStream = new ByteArrayOutputStream();
        BufferedImage image = producer.createImage(code);
        ImageIO.write(image, "jpg", outputStream);
        // 生成captcha的token
        Map<String, Object> map = new HashMap<>();
        UUID codeKey = UUID.randomUUID();
        System.out.println("codeKey:" + codeKey);
        //保存验证码和对应的key
        redisUtils.set("code:" + codeKey, code, TimeUtils.MINUTES);
        map.put("codeKey", codeKey);
        map.put("img", Base64.getEncoder().encodeToString(outputStream.toByteArray()));
        return ResultUtils.success(map);
    }
}

三、编写Kaptcha配置类

import com.google.code.kaptcha.impl.DefaultKaptcha;
import com.google.code.kaptcha.util.Config;
import com.hlw.ac.utils.KaptchaUtils;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;

import java.util.Properties;

/**
 * @ClassName: KaptchaConfig
 * @Description:
 * @author: 阿长
 * @date: 2022/12/4 12:44
 */

@Configuration
public class KaptchaConfig {

    private final static String CODE_LENGTH = "4";
    private final static String CODE_BORDER = "no";
    private final static String CODE_WIDTH = "120";
    private final static String CODE_HEIGHT = "40";
    private final static String CODE_FONT_SIZE = "30";
    private final static String CODE_FONT_COLOR = "black";
    private final static String CODE_FONT_NAMES = "宋体,楷体,黑体";

    @Bean
    public DefaultKaptcha producer() {
        DefaultKaptcha defaultKaptcha = new DefaultKaptcha();
        Properties properties = new Properties();
        // 设置边框
        properties.setProperty("kaptcha.border", CODE_BORDER);
        // 设置字体颜色
        properties.setProperty("kaptcha.textproducer.font.color", CODE_FONT_COLOR);
        // 设置图片宽度
        properties.setProperty("kaptcha.image.width", CODE_WIDTH);
        // 设置图片高度
        properties.setProperty("kaptcha.image.height", CODE_HEIGHT);
        // 设置字体尺寸
        properties.setProperty("kaptcha.textproducer.font.size", CODE_FONT_SIZE);
        // 设置验证码长度
        properties.setProperty("kaptcha.textproducer.char.length", CODE_LENGTH);
        // 设置字体
        properties.setProperty("kaptcha.textproducer.font.names", CODE_FONT_NAMES);
        Config config = new Config(properties);
        defaultKaptcha.setConfig(config);
        return defaultKaptcha;
    }

    @Bean
    public KaptchaUtils kaptchaUtils() {
        return new KaptchaUtils();
    }

}

四、PostMan测试验证

五、BASE64转图片测试

网站链接:https://tool.jisuapi.com/base642pic.html

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

阿长@

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值