首先进行导入相应的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);
}
这样就进行相应的验证码的实现了。