kaptcha验证码插件的使用

时间:2022-09-02 14:00:37

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

  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>
  1. <servlet-mapping>
  2. <servlet-name>kaptcha</servlet-name>
  3. <url-pattern>/ClinicCountManager/kaptcha.jpg</url-pattern>
  4. lt;/servlet-mapping>

jsp 页面使用

  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中配置

  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>

新建生成图片控制类

  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. }

前台调用方式

  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>

取验证码的方式

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

如果需要全部数字

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

去掉干扰线

  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>

kaptcha验证码插件的使用的更多相关文章

  1. kaptcha验证码插件使用与参数

    kaptcha使用1 kaptcha使用2 kaptcha使用3 kaptcha参数说明

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

    Kaptcha验证码 是google提供的验证码插件,使用起来相对简单,设置的干扰线以及字体扭曲不易让其他人读取破解. 这里我们需要 导入一个 kaptcha-2.3.jar  下载地址:http:/ ...

  3. kaptcha验证码使用

    参数配置: Constant 描述 默认值 kaptcha.border 图片边框,合法值:yes , no yes kaptcha.border.color 边框颜色,合法值: r,g,b (and ...

  4. kaptcha 验证码组件使用

    kaptcha 验证码组件使用简介   kaptcha 是一个非常实用的验证码生成工具.有了它,你可以生成各种样式的验证码,因为它是可配置的.kaptcha工作的原理是调用 com.google.co ...

  5. KAPTCHA验证码使用步骤

    使用kaptcha可以方便的配置: · 验证码的字体 · 验证码字体的大小 · 验证码字体的字体颜色 · 验证码内容的范围(数字,字母,中文汉字!) · 验证码图片的大小,边框,边框粗细,边框颜色 · ...

  6. kaptcha验证码的使用

    使用kaptcha可以方便的配置: 验证码的字体 验证码字体的大小 验证码字体的字体颜色 验证码内容的范围(数字,字母,中文汉字!) 验证码图片的大小,边框,边框粗细,边框颜色 验证码的干扰线(可以自 ...

  7. jcaptcha和kaptcha验证码使用入门【转】

    jcaptcha和kaptcha验证码使用入门 一.jcaptcha验证码使用 jcaptcha使用默认样式生成的验证码比较难以识别,所以需要自定义验证码的样式,包括,背景色.背景大小.字体.字体大小 ...

  8. kaptcha验证码实现,配合spring boot使用

    一.kaptcha介绍 Kaptcha是谷歌放在github上的一个验证码jar包,我们可以简单配置属性实现验证码的验证功能. kaptcha参数设置如下所示: Constant 描述 默认值 kap ...

  9. django-simple-captcha 验证码插件介绍 django-simple-captcha 使用 以及添加动态ajax刷新验证

    django-simple-captcha作为一款django的验证码插件,使用方法非常简单,能够快速应用到web应用中. 文档官网地址:django-simple-captcha 参考博客:http ...

随机推荐

  1. 自动布局报错(两条连线冲突):Unable to simultaneously satisfy constraints

    这个报错有些长: Unable to simultaneously satisfy constraints.    Probably at least one of the constraints i ...

  2. hdoj 1251 统计难题&lpar;字典树&rpar;

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1251 思路分析:该问题要求求出以某个字符串为前缀的单词数目,通过使用字典树,在字典树中添加count记 ...

  3. lcc之内存分配

    现在感觉这本书有些地方没有说透,如果自己的理解能力与基础知识够强的话,理解起来还好,如果不行的话,某些地方理解起来会相当的头疼. 现在来说说内存管理.当初看这一章的时候很快就过去了,感觉很多地方很好理 ...

  4. 如何一步一步用DDD设计一个电商网站(十四)—— 回顾与总结

    本系列所有文章 如何一步一步用DDD设计一个电商网站(一)—— 先理解核心概念 如何一步一步用DDD设计一个电商网站(二)—— 项目架构 如何一步一步用DDD设计一个电商网站(三)—— 初涉核心域 如 ...

  5. &dollar;&period;each&lpar;&rpar;遍历json数据

    var json = [ {"id":"1","tagName":"apple"}, {"id":& ...

  6. MySQL优化二 缓存参数优化

    数据库属于 IO密集型的应用程序,其主要职责就是数据的管理及存储工作.而我们知道,从内存中读取一个数据库的时间是微秒级别,而从一块普通硬盘上读取一个IO是在毫秒级别,二者相差3个数量级.所以,要优化数 ...

  7. GitHub For Beginners&colon; Commit&comma; Push And Go

    In Part 1 of this two-part GitHub tutorial, we examined the main uses for GitHub and bega5n the proc ...

  8. C&num; 通过进程名&sol;进程Id 操作窗口&sol;程序

    1. 判断窗口是否存在 private bool IsWindowExist(IntPtr handle) { ) != IntPtr.Zero) && IsWindowVisible ...

  9. Educational Codeforces Round 61 &lpar;Rated for Div&period; 2&rpar;

    A. Regular Bracket Sequence 题意:给出四种括号的数量 ((  )) ()  )( 问是否可以组成合法的序列(只能排序不能插在另外一个的中间) 思路: 条件一:一个或 n个) ...

  10. Missing library&colon; xdoclet-1&period;2&period;1&period;jar&period;如何解决?

    去这里下载xdoclet-bin-1.2.1.zip http://sourceforge.net/projects/xdoclet/files/xdoclet/1.2.1/ 解压出来,比如解压到C: ...