`

验证码生成工具

 
阅读更多
kaptcha 简单方便的验证码生成工具


kaptcha是一个非常实用的验证码生成工具,有了它,你可以生成各种样式的验证码,因为它是可配置的。

kaptcha工作的原理是调用com.google.code.kaptcha.servlet.KaptchaServlet,生成一个图片。同时将生成的验证码字符串放到HttpSession中。

kaptcha可以配置一下信息:

验证码的字体

验证码字体的大小

验证码字体的字体颜色

验证码内容的范围(数字,字母,中文汉字!)

验证码图片的大小,边框,边框粗细,边框颜色

验证码的干扰线(可以自己继承com.google.code.kaptcha.NoiseProducer写一个自定义的干扰线)

验证码的样式(鱼眼样式、3D、普通模糊……当然也可以继承com.google.code.kaptcha.GimpyEngine自定义样式)

……

详细信息请看下面的web.xml文件

下面介绍一下用法:

1.首先去官网下载jar:http://code.google.com/p/kaptcha/

2.建立一个web项目,导入kaptcha-2.3.jar到环境变量中。

3.配置web.xml文件

其实就是配置com.google.code.kaptcha.servlet.KaptchaServlet

[xhtml] view plaincopy

    <?xml version="1.0" encoding="UTF-8"?> 
    <web-app xmlns="http://java.sun.com/xml/ns/j2ee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
        xsi:schemaLocation="http://java.sun.com/xml/ns/j2ee http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd" 
        version="2.4"> 
        <servlet> 
            <servlet-name>Kaptcha</servlet-name> 
            <servlet-class>com.google.code.kaptcha.servlet.KaptchaServlet</servlet-class> 
            <init-param> 
                <description> Border around kaptcha. Legal values are yes or no. </description> 
                <param-name>kaptcha.border</param-name> 
                <param-value>no</param-value> 
            </init-param> 
            <init-param> 
                <description>Color of the border. Legal values are r,g,b (and optional alpha) or white,black,blue. </description> 
                <param-name>kaptcha.border.color</param-name> 
                <param-value>red</param-value> 
            </init-param> 
            <init-param> 
                <description>Thickness of the border around kaptcha. Legal values are > 0. </description> 
                <param-name>kaptcha.border.thickness</param-name> 
                <param-value>5</param-value> 
            </init-param> 
            <init-param> 
                <description>Width in pixels of the kaptcha image. </description> 
                <param-name>kaptcha.image.width</param-name> 
                <param-value>80</param-value> 
            </init-param> 
            <init-param> 
                <description>Height in pixels of the kaptcha image. </description> 
                <param-name>kaptcha.image.height</param-name> 
                <param-value>40</param-value> 
            </init-param> 
            <init-param> 
                <description>The image producer. </description> 
                <param-name>kaptcha.producer.impl</param-name> 
                <param-value>com.google.code.kaptcha.impl.DefaultKaptcha </param-value> 
            </init-param> 
            <init-param> 
                <description>The text producer. </description> 
                <param-name>kaptcha.textproducer.impl</param-name> 
                <param-value>com.google.code.kaptcha.text.impl.DefaultTextCreator</param-value> 
            </init-param> 
            <init-param> 
                <description>The characters that will create the kaptcha. </description> 
                <param-name>kaptcha.textproducer.char.string</param-name> 
                <param-value>abcde2345678gfynmnpwx </param-value> 
            </init-param> 
            <init-param> 
                <description>The number of characters to display. </description> 
                <param-name>kaptcha.textproducer.char.length</param-name> 
                <param-value>5</param-value> 
            </init-param> 
            <init-param> 
                <description>A list of comma separated font names.</description> 
                <param-name>kaptcha.textproducer.font.names</param-name> 
                <param-value>Arial, Courier</param-value> 
            </init-param> 
            <init-param> 
                <description>The size of the font to use. </description> 
                <param-name>kaptcha.textproducer.font.size</param-name> 
                <param-value>23</param-value> 
            </init-param> 
            <init-param> 
                <description>The color to use for the font. Legal values are r,g,b. </description> 
                <param-name>kaptcha.textproducer.font.color</param-name> 
                <param-value>black</param-value> 
            </init-param> 
            <init-param> 
                <description>The noise producer. </description> 
                <param-name>kaptcha.noise.impl</param-name> 
                <param-value>com.google.code.kaptcha.impl.NoNoise </param-value> 
            </init-param> 
            <init-param> 
                <description>The noise color. Legal values are r,g,b. </description> 
                <param-name>kaptcha.noise.color</param-name> 
                <param-value>black</param-value> 
            </init-param> 
            <init-param> 
                <description>The obscurificator implementation. </description> 
                <param-name>kaptcha.obscurificator.impl</param-name> 
                <param-value>com.google.code.kaptcha.impl.ShadowGimpy</param-value> 
            </init-param> 
            <init-param> 
                <description>The background implementation. </description> 
                <param-name>kaptcha.background.impl</param-name> 
                <param-value>com.google.code.kaptcha.impl.DefaultBackground</param-value> 
            </init-param> 
            <init-param> 
                <description>Ending background color. Legal values are r,g,b. </description> 
                <param-name>kaptcha.background.clear.to</param-name> 
                <param-value>white</param-value> 
            </init-param> 
            <init-param> 
                <description>The word renderer implementation. </description> 
                <param-name>kaptcha.word.impl</param-name> 
                <param-value>com.google.code.kaptcha.text.impl.DefaultWordRenderer</param-value> 
            </init-param> 
            <init-param> 
                <description>The value for the kaptcha is generated and is put into the HttpSession. This is the key value for that item in the session. </description> 
                <param-name>kaptcha.session.key</param-name> 
                <param-value>KAPTCHA_SESSION_KEY</param-value> 
            </init-param> 
            <init-param> 
                <description>The date the kaptcha is generated is put into the HttpSession. This is the key value for that item in the session. </description> 
                <param-name>kaptcha.session.date</param-name> 
                <param-value>KAPTCHA_SESSION_DATE</param-value> 
            </init-param> 
        </servlet> 
        <servlet-mapping> 
            <servlet-name>Kaptcha</servlet-name> 
            <url-pattern>/Kaptcha.jpg</url-pattern> 
        </servlet-mapping> 
        <welcome-file-list> 
            <welcome-file>KaptchaExample.jsp</welcome-file> 
        </welcome-file-list> 
    </web-app> 



4.编写KaptchaExample.jsp

这里用到了jQuery,所以添加了jQuery的库

[javascript] view plaincopy

    <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> 
    <html> 
        <head> 
            <%@ page language="java" contentType="text/html; charset=UTF-8"%> 
            <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"> 
            <title>Kaptcha Example</title> 
            <mce:script type="text/javascript" src="js/jquery-1.3.2.js" mce_src="js/jquery-1.3.2.js"></mce:script> 
        </head> 
        <body> 
            Enter in the 
            <a href="http://code.google.com/p/kaptcha/" mce_href="http://code.google.com/p/kaptcha/">Kaptcha</a> to see if it 
            matches what is stored in the session attributes. 
            <table> 
                <tr> 
                    <td> 
                        <img src="Kaptcha.jpg" mce_src="Kaptcha.jpg" id="kaptchaImage" /> 
                        <mce:script type="text/javascript"><!-- 
    $('#kaptchaImage').click( 
            function() { 
                $(this).hide().attr('src', 
                        'Kaptcha.jpg?' + Math.floor(Math.random() * 100)).fadeIn(); 
            }) 
    // --></mce:script> 
                        <br /> 
                        单击换图片 
                    </td> 
                    <td valign="top"> 
                        <form method="POST"> 
                            <br> 
                            验证码:: 
                            <input type="text" name="kaptchafield"> 
                            <br /> 
                            <input type="submit" name="submit"> 
                        </form> 
                    </td> 
                </tr> 
            </table> 
            <br /> 
            <br /> 
            <br /> 
            <br /> 
            <% 
                String c = (String) session 
                        .getAttribute(com.google.code.kaptcha.Constants.KAPTCHA_SESSION_KEY); 
                String parm = (String) request.getParameter("kaptchafield"); 
                 
                System.out.println(c); 
                out.println("Parameter: " + parm + " ? Session Key: " + c + " : "); 
                if (c != null && parm != null) 
                { 
                    if (c.equals(parm)) 
                    { 
                        out.println("<b>true</b>"); 
                    } else 
                    { 
                        out.println("<b>false</b>"); 
                    } 
                } 
            %> 
        </body> 
    </html>
分享到:
评论

相关推荐

    验证码生成工具类

    验证码生成工具类是一种在Web应用中广泛使用的安全机制,它主要用于防止自动化的恶意操作,比如机器人注册、垃圾邮件发送等。这个工具类是用Java语言编写的,因此我们可以深入探讨一下Java验证码生成的相关技术和...

    轻量级验证码生成工具

    本篇将详细探讨“轻量级验证码生成工具”——一个基于Java的验证码生成插件。 该插件设计的目标是轻便且易于集成,它内置了四种不同的验证码样式,可以满足各种应用场景的需求。这些样式可能包括不同颜色、字体、...

    dotnet-HeiCaptcha一个netcore跨平台的图形验证码生成工具包

    标题中的"dotnet-HeiCaptcha"是一个专为.NET Core设计的图形验证码生成库,强调了其跨平台的特性。这意味着它不仅能在Windows系统上运行,还能在Linux或macOS等其他支持.NET Core的平台上工作。"HeiCaptcha"这个名字...

    php验证码生成工具

    一个php验证码生成工具,&lt;img src="authCode.php"&gt;

    kaptcha是google开源的一个非常实用的验证码生成工具类,里面包含kaptcha jar包和打包命令

    kaptcha是一个Java实现的验证码生成工具,它的主要功能是生成随机且具有可读性的图像验证码。kaptcha-2.3.2是这个项目的特定版本,包含了该版本的jar包,这使得开发者可以直接引入项目中使用,无需从源码编译。 在...

    验证码的生成工具 Java

    本项目提供的是一款用Java编写的验证码生成工具,包括showyanzhengma.exe可执行文件、yanzhengma6(50).exe以及yanzhengma6(50).jar文件。 验证码的生成通常包含以下几个关键步骤: 1. **随机字符生成**:验证码...

    图片验证码生成工具类

    这个是生成图片验证码的工具,可以直接使用的,使用教程在https://blog.csdn.net/qq_31844349/article/details/97185842,这个只适合学习使用,不能用在商业软件中,可能会存在BUG,所以不能使用在系统软件开发中,如果您...

    验证码生成工具jar.rar

    vericode 验证码jar包, ValidateCode.jar CAPTCHAResult.java

    验证码生成工具类+验证码验证学习笔记

    本文将详细介绍一个基于Java实现的验证码生成工具类及其验证过程。 首先,验证码工具类的核心功能是生成具有随机性且难以被机器识别的图像。在这个例子中,代码定义了图像的宽度、高度、字符数量以及干扰线条数。`...

    kaptcha验证码生成工具

    Kaptcha是一个用Java编写的开源验证码生成器,适用于各种Web应用,旨在提供简单而强大的解决方案来创建难以识别但又不会困扰用户的验证码。 Kaptcha-2.3.2.jar是该工具包的核心库文件,包含了生成验证码所需的所有...

    ValidateCodeUtils.java随机生成验证码工具类 长度为4位或者6位

    随机生成验证码工具类 长度为4位或者6位

    Java图片验证码生成工具类

    好看的图片验证码,包含干扰线、噪点、扭曲图片等。。

    验证码生成工具类.txt

    随机生成验证码的工具类封装

    谷歌验证码使用工具——kaptcha-2.3.2

    【谷歌验证码使用工具——kaptcha-2.3.2】是一款基于Java的开源验证码生成库,主要用于网站的身份验证,防止自动化的机器人或者恶意攻击者进行非法操作。kaptcha这个名字是"CAPTCHA"(Completely Automated Public ...

    Java生成图片验证码工具类源码

    该工具类使用随机字符生成验证码,并支持自定义验证码长度和字体样式。生成的验证码图片背景透明,线条清晰,可轻松辨认。本源码包含了工具类源码及调用示例,可供开发者参考使用,集成到您的项目中。

    java图形验证码生成工具类 web页面校验验证码

    Java图形验证码生成工具类是用于在Web页面上创建安全的随机验证码图像的程序。验证码的主要目的是防止自动机器人或恶意软件进行非法操作,如批量注册、恶意登录等。它通过要求用户输入显示在图像中的随机字符序列来...

Global site tag (gtag.js) - Google Analytics