Spring Boot整合Security系列步骤及问题排查(五)—— 自定义图形验证码校验

本文详细介绍了如何在Spring Boot项目中结合Spring Security进行图形验证码的集成。首先创建了图形验证码实体类,然后通过控制器生成验证码。接着,自定义了一个验证码拦截器,并在WebSecurityConfig中进行配置。此外,还更新了登录页面以显示验证码。最后,文章提到了可能遇到的问题及解决办法。
摘要由CSDN通过智能技术生成

1.新建图形验证码实体类:

/**
 * 图片验证码
 *
 * @author zhaohaibin
 */
@Data
public class ImageCode {
   

    private BufferedImage image;
    private String code;
    private LocalDateTime expireTime;

    /**
     * @param image
     * @param code
     * @param expireIn - 超时时间(秒)
     */
    public ImageCode(BufferedImage image, String code, int expireIn) {
   
        this.image = image;
        this.code = code;
        this.expireTime = LocalDateTime.now().plusSeconds(expireIn);
    }

    public ImageCode(BufferedImage image, String code, LocalDateTime expireTime) {
   
        this.image = image;
        this.code = code;
        this.expireTime = expireTime;
    }

    /**
     * 是否过期验证
     *
     * @return
     */
    public boolean isExpried() {
   
        return LocalDateTime.now().isAfter(expireTime);
    }
}

2.新建图形验证码控制器及生成逻辑:

/**
 * 验证码控制器
 *
 * @author zhaohaibin
 */
@RestController
public class ValidateCodeController {
   

    public static final String SESSION_KEY = "SESSION_KEY_IMAGE_CODE";

    private SessionStrategy sessionStrategy = new HttpSessionSessionStrategy();

    @GetMapping("/code/image")
    public void createCode(HttpServletRequest request, HttpServletResponse response) throws IOException {
   
        ImageCode imageCode = createImageCode(request);
        sessionStrategy.setAttribute(new ServletWebRequest(request), SESSION_KEY, imageCode);
        ImageIO.write(imageCode.getImage(), "JPEG", response.getOutputStream());
    }

    /**
     * 生成图形验证码
     *
     * @param request
     * @return
     */
    private ImageCode createImageCode(HttpServletRequest request) {
   

        int width = 67;
        int height = 23;

        BufferedImage image = new BufferedImage(width, height, BufferedImage.TYPE_INT_RGB);

        Graphics g =<
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值