zoukankan      html  css  js  c++  java
  • Java Web中Kaptcha实现验证码

    首先进行导入相应的jar包:

           1.如果是maven项目,在你的pom文件中进行添加如下代码,将自动下载jar包到你的工程中:

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

            2.如果是普通的web项目的话,在网上下载/。将此jar包加入到web的lib目录下面,将jar导入的build path中即可使用。

    之后再web中进行相应的配置,代码如下:

     <servlet>
            <!– 生成图片的Servlet –>
            <servlet-name>Kaptcha</servlet-name>
            <servlet-class>com.google.code.kaptcha.servlet.KaptchaServlet</servlet-class>
           
            <!– 是否有边框–>
            <init-param>
                <param-name>kaptcha.border</param-name>
                <param-value>no</param-value>
            </init-param>   
            <!– 字体颜色 –>
            <init-param>
                <param-name>kaptcha.textproducer.font.color</param-name>
                <param-value>red</param-value>
            </init-param>
            <!– 图片宽度 –>
            <init-param>
                <param-name>kaptcha.image.width</param-name>
                <param-value>135</param-value>
            </init-param>
            <!– 使用哪些字符生成验证码 –>
            <init-param>
                <param-name>kaptcha.textproducer.char.string</param-name>
                <param-value>ACDEFHKPRSTWX345679</param-value>
            </init-param>
            <!– 图片高度 –>
            <init-param>
                <param-name>kaptcha.image.height</param-name>
                <param-value>50</param-value>
            </init-param>
            <!– 字体大小 –>
            <init-param>
                <param-name>kaptcha.textproducer.font.size</param-name>
                <param-value>43</param-value>
            </init-param>
            <!– 干扰线的颜色 –>
            <init-param>
                <param-name>kaptcha.noise.color</param-name>
                <param-value>black</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>Arial</param-value>
            </init-param>       
        </servlet>
        <!– 映射的url –>
        <servlet-mapping>
            <servlet-name>Kaptcha</servlet-name>
            <url-pattern>/Kaptcha</url-pattern>
        </servlet-mapping>

    前端的html或者jsp中的form中验证码的代码:

    <div class="form-group">
                            <label for="j_captcha" class="t">验证码:</label>
                             <input id="j_captcha" name="j_captcha" type="text" class="form-control x164 in">
                            <img id="captcha_img" alt="点击更换" title="点击更换" onclick="changeVerifyCode(this)" src="Kaptcha" class="m">
     </div>

    这里的src="Kaptcha"是跳转到相应的servlet中进行加载验证码。   点击刷新验证码是一个js进行控制的。js的脚本为:

    点击切换验证码
        function changeVerifyCode(img){
            img.src = "Kaptcha?"+Math.floor(Math.random()*100);   
        }

    这是一个javascript脚本。这样就实现了刷新验证码。

    生成了相应的验证码,那我们怎么去使用呢?怎么样去得到验证码呢?怎么样让验证码不区分大小写呢?这些都在后台的action进行控制。

     public void login(HttpServletRequest request,HttpServletResponse response,String kachepa) throws IOException{
          
            String kaptchaExpected = (String)request.getSession()
                    .getAttribute(com.google.code.kaptcha.Constants.KAPTCHA_SESSION_KEY);   这里是得到相应的验证码
            if( kachepa.equalsIgnoreCase(kaptchaExpected)//){    //验证码不区分大小写
                setJsonString("{"success":true}");
            }else if(!kachepa.equalsIgnoreCase(kaptchaExpected)){
                setJsonString("{"success":false,"result":"验证码不正确!"}");
            }
            this.outPrintJsonString(response, jsonString);
        }

    这样就进行相应的验证码的实现了。

  • 相关阅读:
    【新特性速递】卡片式表格,Yeah~~~
    6个最佳DevOps播客
    在裸金属服务器Bare Metal上Kubernetes
    保护Java应用程序不被窃取数据和源代码2
    家政服务行业动态
    15个免费数据集数据科学项目
    性能测试工具
    利用Apache Pulsar的实时边缘计算
    软件开发的八个误解
    如何防止范围蔓延
  • 原文地址:https://www.cnblogs.com/tonylovett/p/4615771.html
Copyright © 2011-2022 走看看