使用Kaptcha实现的验证码功能

目录

一.需求

二.验证码功能实现步骤

验证码

引入kaptcha依赖

完成application.yml配置文件

浏览器显示验证码

前端页面

登录页面

验证成功页面

后端


此验证码功能是以SpringBoot框架下基于kaptcha插件来实现的。

一.需求

1.页面生成验证码

2.输入验证码,点击提交,验证用户输入的验证码是否正确,正确则进行页面跳转

二.验证码功能实现步骤

1.生成内容(根据词库)

2.生成干扰项

3.二者组成图片,返回

验证码

引入kaptcha依赖

复制代码
<dependency>
			<groupId>com.oopsguy.kaptcha</groupId>
			<artifactId>kaptcha-spring-boot-starter</artifactId>
			<version>1.0.0-beta-2</version>
</dependency>

完成application.yml配置文件

html 复制代码
kaptcha:
#  图片大小
  image:
    width: 100
    height: 60
#  字体
  text-producer:
    font:
      size: 28
  items:
#    home captcha
    admin:
     path: /admin/captcha
     session:
       key: HOME_KAPTCHA_SESSION_KEY
       data: HOME_KAPTCHA_SESSION_DATE

浏览器显示验证码

运行:即可在浏览器访问验证码

前端页面

登录页面

html 复制代码
<!DOCTYPE html>
<html lang="en">

<head>
  <meta charset="utf-8">

  <title>验证码</title>
  <style>
    #inputCaptcha {
      height: 30px;
      vertical-align: middle; 
    }
    #verificationCodeImg{
      vertical-align: middle; 
    }
    #checkCaptcha{
      height: 40px;
      width: 100px;
    }
  </style>
</head>

<body>
  <h1>输入验证码</h1>
  <div id="confirm">
    <input type="text" name="inputCaptcha" id="inputCaptcha">
    <img id="verificationCodeImg" src="/admin/captcha" style="cursor: pointer;" title="看不清?换一张" />
    <input type="button" value="提交" id="checkCaptcha">
  </div>
  <script src="https://cdn.bootcdn.net/ajax/libs/jquery/3.6.4/jquery.min.js"></script>
  <script>
    
    $("#verificationCodeImg").click(function(){
      $(this).hide().attr('src', '/admin/captcha?dt=' + new Date().getTime()).fadeIn();
    });

    $("#checkCaptcha").click(function () {
      $.ajax({
        type:"get",
        url:"/admin/check",
        data:{
          captcha:$("#inputCaptcha").val()
        },
        success:function(result){
          if(result){
            location.href="success.html";
          }else{
            alert("验证码错误");
          }
        }
      });
    });

  </script>
</body>

</html>

验证成功页面

html 复制代码
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>验证成功页</title>
</head>
<body>
    <h1>验证成功</h1>
</body>
</html>

后端

java 复制代码
package com.lele.demo.controller;

import org.springframework.util.StringUtils;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

import javax.servlet.http.HttpSession;
import javax.xml.crypto.Data;
import java.util.Date;

@RequestMapping("/admin")
@RestController
public class CaptchaController {
    private static final String KAPTCHA_SESSION_KEY= "HOME_KAPTCHA_SESSION_KEY";
    private static final String KAPTCHA_SESSION_DATE="HOME_KAPTCHA_SESSION_DATE";
    //一分钟60秒,一秒1000毫秒
    private static final Long SESSION_TIME_OUT=60*1000L;

//    1.从session中获取生成的验证码
//    2.对比前端的验证码与session中的是否一样
    //验证成功返回true 失败返回false
    @RequestMapping("/check")
    public Boolean check(String captcha ,HttpSession session){
        if(!StringUtils.hasLength(captcha)){
            return false;
        }
        //从session中获取验证码
        String saveCaptcha=(String) session.getAttribute(KAPTCHA_SESSION_KEY);
        Date saveDate=(Date) session.getAttribute(KAPTCHA_SESSION_DATE);
        //比对验证码
        if(captcha.equals(saveCaptcha)){
            //比对日期
            if(saveDate==null || System.currentTimeMillis()-saveDate.getTime()<SESSION_TIME_OUT){
                return true;
            }
            return true;
        }
        return false;
    }
}

测试后端代码

实现结果

相关推荐
dkbnull18 分钟前
深入理解Spring两大特性:IoC和AOP
spring boot
考虑考虑1 小时前
JDK25模块导入声明
java·后端·java ee
_小马快跑_2 小时前
Java 的 8 大基本数据类型:为何是不可或缺的设计?
java
Re_zero5 小时前
线上日志被清空?这段仅10行的 IO 代码里竟然藏着3个毒瘤
java·后端
洋洋技术笔记5 小时前
Spring Boot条件注解详解
java·spring boot
程序员清风1 天前
程序员兼职必看:靠谱软件外包平台挑选指南与避坑清单!
java·后端·面试
皮皮林5511 天前
利用闲置 Mac 从零部署 OpenClaw 教程 !
java
NE_STOP1 天前
springMVC-HTTP消息转换器与文件上传、下载、异常处理
spring
洋洋技术笔记1 天前
Spring Boot配置管理最佳实践
spring boot
华仔啊1 天前
挖到了 1 个 Java 小特性:var,用完就回不去了
java·后端