对于一个WEB项目中,为了防止及其程序破解用户名和密码通常会采取验证码的措施。
把用到过的一个验证码的例子贴出来与大家分享,这个例子很简单,是别人已经把java代码封装好,要使用的话只需简单的配置即可。
1、到网上下载Kaptcha的jar包,下面已提供了下载,加入到lib目录下(不要告诉我不知道这个文件夹)
2、在web.xml中进行如下配置:
<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>/randomcode</url-pattern>
</servlet-mapping>
3、搞好这一步,就可以在jsp页面中使用了,简单吧 ,给出使用的具体代码:
<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>randomcode</title>
<script type="text/javascript">
function changeR(node){
// 用于点击时产生不同的验证码
node.src = "randomcode?time="+new Date().getTime() ;
}
</script>
</head>
<body>
<img alt="random" src="randomcode" οnclick="changeR(this)" style="cursor: pointer;">
<form action="check.jsp">
<input type="text" name="r">
<input type="submit" value="s">
</form>
</body>
</html>
4、好,现在就写一个简单jsp面来验证一下:check.jsp
<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>check</title>
</head>
<body>
<%
// 检查是否是正确的验证码
String k = (String) session
.getAttribute(com.google.code.kaptcha.Constants.KAPTCHA_SESSION_KEY);
String str = request.getParameter("r");
if (k.equals(str))
out.print("true");
out.print(k + "---" + str);
%>
</body>
</html>
到此简单的demo就Ok了,老规矩来几张图片,更好说明问题。
附上dmeo下载地址:http://download.csdn.net/detail/akwolf/3647428