kaptcha 验证码组件使用

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文件

Java代码  

  1. <!--Kaptcha 验证码  --><!--
  2. <servlet>
  3. <servlet-name>kaptcha</servlet-name>
  4. <servlet-class>com.google.code.kaptcha.servlet.KaptchaServlet</servlet-class>
  5. <init-param>
  6. <param-name>kaptcha.border</param-name>
  7. <param-value>no</param-value>
  8. </init-param>
  9. <init-param>
  10. <param-name>kaptcha.border.color</param-name>
  11. <param-value>105,179,90</param-value>
  12. </init-param>
  13. <init-param>
  14. <param-name>kaptcha.textproducer.font.color</param-name>
  15. <param-value>red</param-value>
  16. </init-param>
  17. <init-param>
  18. <param-name>kaptcha.image.width</param-name>
  19. <param-value>250</param-value>
  20. </init-param>
  21. <init-param>
  22. <param-name>kaptcha.image.height</param-name>
  23. <param-value>90</param-value>
  24. </init-param>
  25. <init-param>
  26. <param-name>kaptcha.textproducer.font.size</param-name>
  27. <param-value>70</param-value>
  28. </init-param>
  29. <init-param>
  30. <param-name>kaptcha.session.key</param-name>
  31. <param-value>code</param-value>
  32. </init-param>
  33. <init-param>
  34. <param-name>kaptcha.textproducer.char.length</param-name>
  35. <param-value>4</param-value>
  36. </init-param>
  37. <init-param>
  38. <param-name>kaptcha.textproducer.font.names</param-name>
  39. <param-value>宋体,楷体,微软雅黑</param-value>
  40. </init-param>
  41. </servlet>

Java代码  

  1. <servlet-mapping>
  2. <servlet-name>kaptcha</servlet-name>
  3. <url-pattern>/ClinicCountManager/kaptcha.jpg</url-pattern>
  4. lt;/servlet-mapping>

jsp 页面使用

Java代码  

  1. <table>
  2. <tr>
  3. <td><img src="/ClinicCountManager/kaptcha.jpg"></td>
  4. <td valign="top">
  5. <form method="POST">
  6. <br>sec code:<input type="text" name="kaptchafield"><br />
  7. <input type="submit" name="submit">
  8. </form>
  9. </td>
  10. </tr>
  11. </table>
  12. <br /><br /><br /><br />
  13. <%
  14. String c = (String)session.getAttribute(com.google.code.kaptcha.Constants.KAPTCHA_SESSION_KEY);
  15. String parm = (String) request.getParameter("kaptchafield");
  16. out.println("Parameter: " + parm + " ? Session Key: " + c + " : ");
  17. if (c != null && parm != null) {
  18. if (c.equals(parm)) {
  19. out.println("<b>true</b>");
  20. } else {
  21. out.println("<b>false</b>");
  22. }
  23. %>

上面的配置在普通jsp环境下面是有效的,如果在spring mvc环境下,则取不到session值,对于sping mvc环境验证码配置如下:

1.不用在web.xml进行相关配置,在applicationContext.xml中配置

Java代码  

  1. <bean id="captchaProducer" class="com.google.code.kaptcha.impl.DefaultKaptcha">
  2. <property name="config">
  3. <bean class="com.google.code.kaptcha.util.Config">
  4. <constructor-arg>
  5. <props>
  6. <prop key="kaptcha.border">no</prop>
  7. <prop key="kaptcha.border.color">105,179,90</prop>
  8. <prop key="kaptcha.textproducer.font.color">red</prop>
  9. <prop key="kaptcha.image.width">250</prop>
  10. <prop key="kaptcha.textproducer.font.size">90</prop>
  11. <prop key="kaptcha.image.height">90</prop>
  12. <prop key="kaptcha.session.key">code</prop>
  13. <prop key="kaptcha.textproducer.char.length">4</prop>
  14. <prop key="kaptcha.textproducer.font.names">宋体,楷体,微软雅黑</prop>
  15. </props>
  16. </constructor-arg>
  17. </bean>
  18. </property>
  19. </bean>

新建生成图片控制类

Java代码  

  1. import java.awt.image.BufferedImage;
  2. import javax.imageio.ImageIO;
  3. import javax.servlet.ServletOutputStream;
  4. import javax.servlet.http.HttpServletRequest;
  5. import javax.servlet.http.HttpServletResponse;
  6. import org.springframework.beans.factory.annotation.Autowired;
  7. import org.springframework.stereotype.Controller;
  8. import org.springframework.web.bind.annotation.RequestMapping;
  9. import org.springframework.web.servlet.ModelAndView;
  10. import com.google.code.kaptcha.Constants;
  11. import com.google.code.kaptcha.Producer;
  12. @Controller
  13. @RequestMapping("/")
  14. public class CaptchaImageCreateController {
  15. private Producer captchaProducer = null;
  16. @Autowired
  17. public void setCaptchaProducer(Producer captchaProducer) {
  18. this.captchaProducer = captchaProducer;
  19. }
  20. @RequestMapping("/captcha-image")
  21. public ModelAndView handleRequest(HttpServletRequest request, HttpServletResponse response) throws Exception {
  22. response.setDateHeader("Expires", 0);
  23. // Set standard HTTP/1.1 no-cache headers.
  24. response.setHeader("Cache-Control", "no-store, no-cache, must-revalidate");
  25. // Set IE extended HTTP/1.1 no-cache headers (use addHeader).
  26. response.addHeader("Cache-Control", "post-check=0, pre-check=0");
  27. // Set standard HTTP/1.0 no-cache header.
  28. response.setHeader("Pragma", "no-cache");
  29. // return a jpeg
  30. response.setContentType("image/jpeg");
  31. // create the text for the image
  32. String capText = captchaProducer.createText();
  33. // store the text in the session
  34. request.getSession().setAttribute(Constants.KAPTCHA_SESSION_KEY, capText);
  35. // create the image with the text
  36. BufferedImage bi = captchaProducer.createImage(capText);
  37. ServletOutputStream out = response.getOutputStream();
  38. // write the data out
  39. ImageIO.write(bi, "jpg", out);
  40. try {
  41. out.flush();
  42. } finally {
  43. out.close();
  44. }
  45. return null;
  46. }
  47. }

前台调用方式

Java代码  

  1. <div class="chknumber">
  2. <label>验证码:
  3. <input name="kaptcha" type="text" id="kaptcha" maxlength="4" class="chknumber_input" />
  4. </label>
  5. <img src="/ClinicCountManager/captcha-image.do" width="55" height="20" id="kaptchaImage"  style="margin-bottom: -3px"/>
  6. <script type="text/javascript">
  7. $(function(){
  8. $(‘#kaptchaImage‘).click(function () {//生成验证码
  9. $(this).hide().attr(‘src‘, ‘/ClinicCountManager/captcha-image.do?‘ + Math.floor(Math.random()*100) ).fadeIn(); })
  10. });
  11. </script>
  12. </div>

取验证码的方式

Java代码  

  1. String code = (String)session.getAttribute(com.google.code.kaptcha.Constants.KAPTCHA_SESSION_KEY);

如果需要全部数字

Java代码  

  1. <init-param>
  2. <param-name>kaptcha.textproducer.char.string</param-name>
  3. <param-value>0123456789</param-value>
  4. </init-param>

去掉干扰线

Java代码  

  1. <init-param>
  2. <param-name>kaptcha.noise.impl</param-name>
  3. <param-value>com.google.code.kaptcha.impl.NoNoise </param-value>
  4. </init-param>
时间: 2024-10-05 04:27:39

kaptcha 验证码组件使用的相关文章

SpringMVC中使用Kaptcha验证码组件生成比较安全的验证码

一 简介 Kaptcha是一个基于SimpleCaptcha的验证码开源项目,在我们的项目中使用Kaptcha组件可以快速生成比较安全的验证码.同时Kaptcha还提供了许多的参数可以让我们自定义生成的验证码样式 jar包的官网下载地址:https://code.google.com/archive/p/kaptcha/downloads 当然,为了照顾一些翻不了墙的同学,我也在51cto上上传了一份Kaptcha最新的的jar包(kaptcha-2.3.2),传送门:http://down.5

google kaptcha 验证码组件使用简介

kaptcha 是一个非常实用的验证码生成工具.有了它,你可以生成各种样式的验证码,因为它是可配置的.kaptcha工作的原理是调用 com.google.code.kaptcha.servlet.KaptchaServlet,生成一个图片.同时将生成的验证码字符串放到 HttpSession中. 使用kaptcha可以方便的配置: 验证码的字体 验证码字体的大小 验证码字体的字体颜色 验证码内容的范围(数字,字母,中文汉字!) 验证码图片的大小,边框,边框粗细,边框颜色 验证码的干扰线(可以自

java 实现登录验证码 (kaptcha 验证码组件)

验证码的作用: 1.防止广告机注册和发帖.评论.2.防止暴力破解密码,特别是有管理员权限的密码. 在这里介绍一种非常实用的验证码生成工具:kaptcha 这个工具,可以生成各种样式的验证码,因为它是可配置的. 而 kaptcha工作的原理,是调用 com.google.code.kaptcha.servlet.KaptchaServlet,生成一个图片.同时将生成的验证码字符串放到 HttpSession中,直接从session中获取这张验证码图片,而不会占用实际内存. 使用 kaptcha 可

Kaptcha 验证码在springMVC中的使用

项目中配置 Kaptcha 验证码分一下几步: 1,添加Maven依赖 <dependency>            <groupId>com.github.axet</groupId>            <artifactId>kaptcha</artifactId>            <version>0.0.9</version>        </dependency> 2,spring容器中

项目记录:登陆( 保存用户名密码 kaptcha验证码 shiro权限管理 RSA加密 非明文保存)

1.登陆页代码 1)引入js <script type="text/javascript" src="${base}/resources/admin/js/jquery.js"></script> <script type="text/javascript" src="${base}/resources/admin/js/jquery.validate.js"></script>

kaptcha验证码插件

发现现在程序员越来越懒了,连验证码都不想自己写了. https://code.google.com/p/kaptcha/downloads/list kaptcha验证码插件,码迷,mamicode.com

Google Kaptcha验证码的使用

原文:http://www.kailing.pub/article/index/arcid/92.html Kaptcha是什么? kaptcha 是谷歌开源的非常实用的验证码生成工具,基于SimpleCaptcha的开源项目.使用Kaptcha 生成验证码十分简单并且参数可以进行自定义.只需添加jar包配置下就可以使用,通过配置,可以自己定义验证码大小.颜色.显示的字符等等.下面就来讲一下如何使用kaptcha生成验证码以及在服务器端取出验证码进行校验. 怎么使用Kaptcha? 1.首先要项

Java实现验证码制作之一Kaptcha验证码

Kaptcha验证码 是google提供的验证码插件,使用起来相对简单,设置的干扰线以及字体扭曲不易让其他人读取破解. 这里我们需要 导入一个 kaptcha-2.3.jar  下载地址:http://pan.baidu.com/s/1dDzw7Bj jar包中有个 KaptchaServlet 的servlet,每次访问都会保存在session 作用域当中 默认保存的名称是 KAPTCHA_SESSION_KEY 你也可以自己设定 保存过名称 看xml中的注释的   “session中存放验证

火狐浏览器kaptcha验证码点击无法刷新问题解决方法

今天用到了谷歌的kaptcha验证码模块.但是发现在火狐浏览器中,使用起来有一点点的问题. 当我们给验证码绑定单击事件时,代码如下: window.onload = function(){ document.getElementById("code_img").onclick = function(){ this.src = "/kaptcha.jpg"; } } 但是我发现在火狐浏览器上,这样写没有办法实现点击验证码图片就刷新的功能.不过在谷歌浏览器却能流畅运行.