java自动生成验证码插件-kaptcha

kaptcha一个很好用的验证码插件,java版的,很不错的一个插件,只用简单的在web.xml中设置几个属性,一个很漂亮的验证码就出来了。其他的参数都可以自己设置,最牛的就是提供了接口,可以自己定义哦。



html页面代码


< form action = "submit.action" >
     < img src = "kaptcha.jpg" /> < input type = "text" name = "kaptcha" value = "" />
</ form >


web.xml配置代码



< servlet >
         < servlet-name >Kaptcha</ servlet-name >
         < servlet-class >com.google.code.kaptcha.servlet.KaptchaServlet</ servlet-class >
</ servlet >
< servlet-mapping >
         < servlet-name >Kaptcha</ servlet-name >
         < url-pattern >/kaptcha.jpg</ url-pattern >
</ servlet-mapping >

java 获取 代码



String kaptchaExpected = (String)request.getSession()
     .getAttribute(com.google.code.kaptcha.Constants.KAPTCHA_SESSION_KEY);
String kaptchaReceived = request.getParameter( "kaptcha" );
 
if (kaptchaReceived == null || !kaptchaReceived.equalsIgnoreCase(kaptchaExpected))
{
     setError( "kaptcha" , "Invalid validation code." );
}

点击显示代码 刷新方法 js方法

< img src = "/kaptcha" width = "200" id = "kaptchaImage" />
< script type = "text/javascript" >
     $(function(){
         $('#kaptchaImage').click(function () {
             $(this).attr('src', '/kaptcha.jpg?' + Math.floor(Math.random()*100) );
         })
     });
</ script >
< br />< small >Can't read the image? Click it to get a new one.</ small >

其他参数设置
<init-param>  
            <param-name>kaptcha.border</param-name>  
            <param-value>yes</param-value>  
        </init-param>  
        <init-param>  
            <param-name>kaptcha.border.color</param-name>  
            <param-value>105,179,90</param-value>  
        </init-param> 
        <init-param>  
            <param-name>kaptcha.textproducer.font.color</param-name>  
            <param-value>black</param-value>  
        </init-param>  
        <init-param>  
            <param-name>kaptcha.image.width</param-name>  
            <param-value>500</param-value>  
        </init-param>  
        <init-param>  
            <param-name>kaptcha.image.height</param-name>  
            <param-value>300</param-value>  
        </init-param>  
        <init-param>  
            <param-name>kaptcha.textproducer.font.size</param-name>  
            <param-value>90</param-value>  
        </init-param>  
        <init-param>  
            <param-name>kaptcha.session.key</param-name>  
            <param-value>code</param-value>  
        </init-param>  
        <init-param>  
            <param-name>kaptcha.textproducer.char.length</param-name>  
            <param-value>4</param-value>  
        </init-param>  
        <init-param>  
            <param-name>kaptcha.textproducer.font.names</param-name>  
            <param-value>宋体,楷体,微软雅黑</param-value>  
        </init-param> 



  • 3
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在使用kaptcha依赖之前,你需要添加相应的依赖项。具体的添加步骤如下: 1. 首先,你需要导入kaptcha的依赖。在你的项目的pom.xml文件中,添加以下代码片段: ``` <!-- 案例2:katpcha,对应kaptcha目录案例 --> <dependency> <groupId>com.github.penggle</groupId> <artifactId>kaptcha</artifactId> <version>2.3.2</version> </dependency> ``` 2. 之后,你需要获取对应类型的captcha对象。在代码中,你可以使用类似以下的方式来获取captcha对象: ```java Captcha captcha = xxx; //获取对应类型的captcha对象 ``` 3. 最后,你可以使用以下三个方法来操作captcha对象: - 使用 `captcha.text()` 方法来获取验证码的结果内容。 - 使用 `captcha.toBase64()` 方法来获取验证码图片的base64编码。 - 使用 `captcha.out(response.getOutputStream())` 方法将验证码图片以流的形式返回给前端。 以上是关于使用kaptcha依赖的一些基本步骤和操作方法。希望能对你有所帮助!<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [SpringBoot业务开发 02、Springboot快速集成验证码【easy-captcha、kaptcha】超好看样式](https://blog.csdn.net/cl939974883/article/details/124132246)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值