JSP 和 Servlet 中的验证码

本教程介绍了如何在 JSP 和 Servlet 中创建验证码。本示例在 Eclipse IDE 中创建并在 tomcat 服务器上运行。

JSP 和 Servlet 中的验证码

本教程介绍了如何在 JSP 和 Servlet 中创建验证码。本示例在 Eclipse IDE 中创建并在 tomcat 服务器上运行。此示例使用以下 jar

  • imaging.jar
  • jstl-1.2.jar
  • simplecaptcha-1.1.1.jar
  • standard.jar

如果您使用 Eclipse 编辑器开发应用程序,应用程序目录结构将如下所示。

1121captcha1.gif

创建此类应用程序有以下步骤:。

步骤1 :

首先,我们在 Eclipse IDE 中创建动态 Web 项目“captcha”。我们再次在 WebContent 文件夹下创建“simplecaptcha.jsp”文件。“simplecaptcha.jsp”的代码如下:

<%@ page language="java" pageEncoding="UTF-8"%>
<%@ page contentType="text/html;charset=UTF-8"%>
<%
request.setCharacterEncoding("UTF-8");
response.setCharacterEncoding("UTF-8");
response.setContentType("text/html; charset=UTF-8");
%>


<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<META http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>Simple CAPTCHA Example</title>
<link href="styles.css" type="text/css" rel="stylesheet" />
<script type="text/javascript">
	function reloadImg() {
		var timestamp = new Date().getTime();
		document.getElementById("captcha").src = "simpleCaptcha.jpg?"
				+ timestamp;
	}
</script>
</head>
<body>
	<center>
		<h3>验证码测试</h3>

		<form action="captchasubmit.jsp" method="post">

			<img id="captcha" src="simpleCaptcha.jpg" /><br /> <a
				href="javascript:reloadImg()">刷新验证码</a> <br /> <input type="text"
				name="answer" /><br> <input type="submit" value="提交">
		</form>
	</center>
</body>
</html>

第2步 :

我们再次在 WebContent 文件夹下创建“captchasubmit.jsp”文件。此文件用于显示验证码正确与否的消息。“captchasubmit.jsp”的代码如下:

<%@ page language="java" pageEncoding="UTF-8"%>
<%@ page contentType="text/html;charset=UTF-8"%>
<%
request.setCharacterEncoding("UTF-8");
response.setCharacterEncoding("UTF-8");
response.setContentType("text/html; charset=UTF-8");
%>

<%@ page import="nl.captcha.Captcha"%>

<%
Captcha captcha = (Captcha) session.getAttribute(Captcha.NAME);
request.setCharacterEncoding("UTF-8");
String answer = request.getParameter("answer");
if (captcha.isCorrect(answer)) {
%>
<b>验证码正确!</b>
<%
} else {
%>
<b>验证码错误!</b>
<%
}
%>


第 3 步:

 现在在 WebContent 文件夹下创建 css 文件夹并在 css 文件夹下创建“styles.css”文件。“styles.css”的代码如下:

body {

color: black;

background-color: white;

font-family: "Helvetica Neue", Arial, Helvetica, Geneva, sans-serif;

}

第四步 :

现在您可以打开“web.xml”文件并修改为:

<?xml version="1.0" encoding="UTF-8"?>

<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"

xmlns="http://java.sun.com/xml/ns/javaee" xmlns:web="http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd"

xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd"

id="WebApp_ID" version="2.5">

<display-name>captcha</display-name>

<servlet>

<servlet-name>SimpleCaptcha</servlet-name>

<servlet-class>nl.captcha.servlet.SimpleCaptchaServlet</servlet-class>

</servlet>

<servlet-mapping>

<servlet-name>SimpleCaptcha</servlet-name>

<url-pattern>/simpleCaptcha.jpg</url-pattern>

</servlet-mapping>

<welcome-file-list>

<welcome-file>simpleCaptcha.jsp</welcome-file>

</welcome-file-list>

</web-app>

第 5 步:

现在下载imaging.jar、jstl-1.2.jar、simplecaptcha-1.1.1.jar 和standard.jar jar 文件并粘贴到“WebContent/WEB-INF/lib”目录下。

第 6 步:

在 tomcat 服务器上运行此应用程序时,以下输出将显示为:

再次在文本输入框中输入验证码,然后单击“提交”按钮。如果您输入无效的验证码,则会显示以下错误消息:

如果匹配验证码显示消息为:

下载代码

下载示例代码

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值