kaptcha是基于SimpleCaptcha的验证码开源项目。

kaptcha是纯配置的,使用起来比较友好。如使用了Servlet,所有配置都在web.xml中。如果你在项目中使用了开源框架(比如SpringMVC),那么配置在该框架的配置文件中。

一、使用Servlet实现

1. 添加依赖的JAR包

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

我这里使用了maven来统一管理jar包,在pom.xml中添加上面的内容。

没有使用的需要自己下载jar包了。

2. 配置web.xml文件

kaptcha都是在web.xml中配置,我们需要在web.xml中配置kaptcha的servlet,具体如下:

<!-- kaptcha -->
<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>

其中的servlet-name和url-pattern都是自己定义的。

kaptcha的所有参数都是有默认的配置,如果我们不显式的配置,则会使用默认的配置。

如要显式配置kaptcha,在配置对应的servlet时,在init-param增加响应的参数配置即可。部分配置如下:

<servlet>
<servlet-name>Kaptcha</servlet-name>
<servlet-class>com.google.code.kaptcha.servlet.KaptchaServlet</servlet-class>
<init-param>
<param-name>kaptcha.image.width</param-name>
<param-value>200</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.char.length</param-name>
<param-value>4</param-value>
</init-param>
<init-param>
<param-name>kaptcha.noise.impl</param-name>
<param-value>com.google.code.kaptcha.impl.NoNoise</param-value>
</init-param>
</servlet>

二、与SpringMVC开源框架集成使用kaptcha

1. 声明CaptchaProducer Bean实例

<bean id="captchaProducer" class="com.google.code.kaptcha.impl.DefaultKaptcha">
  <property name="config">
    <bean class="com.google.code.kaptcha.util.Config">
      <constructor-arg type="java.util.Properties">
        <props>
          <prop key="kaptcha.image.width">100</prop>
          <prop key="kaptcha.image.height">50</prop>
          <prop key="kaptcha.noise.impl">com.google.code.kaptcha.impl.NoNoise</prop>
          <prop key="kaptcha.textproducer.char.string">0123456789abcdefghijklmnopqrstuvwxyz</prop>
          <prop key="kaptcha.textproducer.char.length">4</prop>
        </props>
      </constructor-arg>
    </bean>
  </property>
</bean>

多贴几个配置

<props>
  <!-- 是否有边框 -->
  <prop key="kaptcha.border">no</prop>
  <!-- 设置边框颜色 -->
  <prop key="kaptcha.border.color">105,179,90</prop>
  <!-- 获取中文 -->
  <prop key="kaptcha.textproducer.impl">org.cric.util.ChineseText</prop>
  <!-- 设置字体颜色 -->
  <prop key="kaptcha.textproducer.font.color">black</prop>
  <!-- 设置验证码宽度 -->
  <prop key="kaptcha.image.width">100</prop>
  <!-- 设置验证码高度 -->
  <prop key="kaptcha.image.height">50</prop>
  <!-- 设置字体大小 -->
  <prop key="kaptcha.textproducer.font.size">30</prop>
  <!-- 设置字体个数 -->
  <prop key="kaptcha.textproducer.char.length">4</prop>
  <!-- 设置字体样式 -->
  <prop key="kaptcha.textproducer.font.names">宋体,楷体,微软雅黑</prop>
  <prop key="kaptcha.noise.impl">com.google.code.kaptcha.impl.NoNoise</prop>
  <prop key="kaptcha.textproducer.char.string">0123456789abcdefghijklmnopqrstuvwxyz</prop>
</props>

2. 获取验证码的controller

@Autowired
private Producer captchaProducer; @RequestMapping("/kaptcha.jpg")
public void getCheckCode(HttpServletRequest request, HttpServletResponse response) throws IOException {
  String codeStr = captchaProducer.createText();
  request.getSession().setAttribute(Constants.KAPTCHA_SESSION_KEY, codeStr);
  BufferedImage bi = captchaProducer.createImage(codeStr);
  ServletOutputStream out = response.getOutputStream();
  ImageIO.write(bi, "jpg", out);
  out.flush();
  out.close();
}

三、测试与优化

1. 页面调用

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

2. action校验类

String sessionCode = (String) request.getSession().getAttribute(com.google.code.kaptcha.Constants.KAPTCHA_SESSION_KEY);
String checkCode = request.getParameter("checkCode");
String isSuccess = "";
if (checkCode != null && checkCode.equals(sessionCode)) {
isSuccess = "恭喜您,验证码输入成功!!!";
} else {
isSuccess = "验证码输入失败啦,囧";
}
response.setContentType("text/html; charset=UTF-8");
response.setCharacterEncoding("UTF-8");
PrintWriter pw = response.getWriter();
pw.print(isSuccess);

3.实现页面验证码刷新

<img src="kaptcha.jpg" id="checkcode" onclick="onCheckCode()" title="看不清换一张">
function onCheckCode () {
var date = new Date();
$("#checkcode").attr("src", "kaptcha.jpg?d="+date);
}

4. 效果

如何使用kaptcha验证码组件的更多相关文章

  1. kaptcha 验证码组件使用

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

  2. google kaptcha 验证码组件使用简介

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

  3. kaptcha验证码组件使用简介

    Kaptcha是一个基于SimpleCaptcha的验证码开源项目. 官网地址:http://code.google.com/p/kaptcha/ kaptcha的使用比较方便,只需添加jar包依赖之 ...

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

    验证码的作用: 1.防止广告机注册和发帖.评论.2.防止暴力破解密码,特别是有管理员权限的密码. 在这里介绍一种非常实用的验证码生成工具:kaptcha 这个工具,可以生成各种样式的验证码,因为它是可 ...

  5. 使用kaptcha验证码组件操作演示

    1.创建一个Maven项目 2.在pom.xml中引入相关依赖 <project xmlns="http://maven.apache.org/POM/4.0.0" xmln ...

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

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

  7. 【干货】”首个“ .NET Core 验证码组件

    前言 众所周知,Dotnet Core目前没有图形API,以前的System.Drawing程序集并没有包含在Dotnet Core 1.0环境中.不过在dotnet core labs项目里可以见到 ...

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

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

  9. kaptcha验证码插件的使用

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

随机推荐

  1. 关于css起名

    作者:词晖链接:https://www.zhihu.com/question/19586885/answer/48933504来源:知乎著作权归作者所有,转载请联系作者获得授权. CSS书写顺序 1. ...

  2. 关于jq的load不用回调获取其中dom元素方法

    jq的load方法如果要操作其中的dom元素,需要使用回调,等其加载完了再进行dom元素的获取,今天看我们项目组长写的一段代码,发现不用回调也能获取到其中的元素. 具体是这样写的: <scrip ...

  3. Gdiplus 贴图(助记) -------------------从资源中载入PNG图片

    从资源中载入图片,亦可改为从内从中加载: void LoadResImage(int nResID,Image * &lpImage) { HINSTANCE hIns=AfxGetInsta ...

  4. ArcGIS导出辖区边界点坐标

    1.使用ArcGIS打开.mxd地图文件 2.选择[Geoprocessing][ArcToolbox]  3.展开菜单,选中如图所示菜单,双击打开 4.选择对应的辖区节点   5.点击OK后,会在左 ...

  5. 一个简单的jQuery插件开发实例

    两年前写的一个简单的jQuery插件开发实例,还是可以看看的: <script type="text/javascript" src="jquery-1.7.2.m ...

  6. Fox And Jumping

    Fox And Jumping 题目链接:http://codeforces.com/problemset/problem/512/B dp 若所选卡片能到达区间内任意点,那么所选卡片的最大公约数为1 ...

  7. STS中Maven配置

    最近接触maven, 配置过程中记录一下. STS是解压版的,启动后,可以看到已经有了Maven插件, , 但是,STS也同时给你了一个Maven,但是通常不建议使用STS自带的maven.使用默认的 ...

  8. 【解题报告】Math

    = =本来昨天就该发的,只是断网……. MATH  [题目描述] 小 x正在做他的数学作业,可是作业实在太难了.题目是这样的: 1.给定一个含有N个数的数列 V. 2.你可以从数列中恰好移除 K个数, ...

  9. C# 语言规范_版本5.0 (第1章 介绍)

    1. 介绍 C#(读作“See Sharp”)是一种简洁.现代.面向对象且类型安全的编程语言.C# 起源于 C 语言家族,因此,对于 C.C++ 和 Java 程序员,可以很快熟悉这种新的语言.C# ...

  10. Arch安装fcitx输入法

    安装fcitx,安装gtk.qt模块. [root@ARCH ~]# pacman -S fcitx-im :: There are 4 members in group fcitx-im: :: R ...