基于javaweb的验证码实现

本文介绍了如何在JavaWeb环境中实现验证码功能。包括创建显示数字验证码的loginForm.jsp,生成验证码的validate.jsp页面,以及验证用户输入验证码是否正确的ValidateServlet。当用户输入正确的验证码时,系统将正常进行下一步操作;若输入错误,会提示用户重新输入。

要求:

编写一个表单,显示数字验证码,如果用户看不清,可以点击旁边的按钮“换一张”来重新获取新的验证码,并要求有验证码功能。

loginForm.jsp:登录表单

<%@ page language="java" pageEncoding="utf-8"%>
<html>
	<body>
	<script type="text/javascript">
		function refresh(){
			//生成只包含数字的验证码
			loginForm.imgValidate.src = "validate.jsp?id=" + Math.random();
		}
	</script>
	<form name="loginForm" action="ValidateServlet" method="post">
		请输入验证码:
		<input type="text" name="code" size="10">
		<!-- 生成只包含数字的验证码 -->
		<img name="imgValidate" src="validate.jsp" style="vertical-align: middle;">
		<input type="button" onclick="refresh()" value="换一张"/><br/>
		<input type="submit" value="登录">	
	</form>		
	</body>
</html>

validate.jsp:生成验证码

<%@ page language="java"
	import="java.awt.*"
	import="java.awt.image.BufferedImage"
	import="java.util.*"
	import="javax.imageio.ImageIO"	
	pageEncoding="utf-8"%>
<%
	response.setHeader("Cache-Control","no-cache"); 
	// 在内存中创建图象 
	int width = 60, height = 20;
	BufferedImage image = new BufferedImage(width, height,
		BufferedImage.TYPE_INT_RGB);
	//获取画笔
	Graphics g = image.getGraphics();
	//设定背景色 
	g.setColor(new Color(200, 200, 200));
	g.fillRect(0, 0, width, height);
	//取随机产生的验证码(4位数字) 
	Random rnd = new Random();
	int randNum = rnd.nextInt(8999) + 1000;
	String randStr = String.valueOf(randNum);
	//将验证码存入session
	session.setAttribute("randStr", randStr);
	//将验证码显示到图象中 
	g.setColor(Color.black);
	g.setFont(new Font("", Font.PLAIN, 20));
	g.drawString(randStr, 10, 17);
	// 随机产生100个干扰点,使图象中的验证码不易被其他程序探测到 
	for (int i = 0; i < 100; i++){
		int x = rnd.nextInt(width);
		int y = rnd.nextInt(height);
		g.drawOval(x, y, 1, 1);
	}
	// 输出图象到页面 
	ImageIO.write(image, "JPEG", response.getOutputStream());
	out.clear();
	out = pageContext.pushBody();
%>

ValidateServlet:验证输入的验证码是否正确

package servlet;

import java.io.IOException;
import java.io.PrintWriter;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;

public class ValidateServlet extends HttpServlet {

	private static final long serialVersionUID = 1L;

	public void doPost(HttpServletRequest request, HttpServletResponse response)
			throws ServletException, IOException {
		//得到提交的验证码
		String code = request.getParameter("code");
		//获取session中的验证码
		HttpSession session = request.getSession();
		String randStr = (String)session.getAttribute("randStr");
		response.setCharacterEncoding("utf-8");
		PrintWriter out = response.getWriter();
		if(!code.equals(randStr)){
			out.println("验证码错误");
		}
		else{
			out.println("验证码正确! <br> 跳转到LoginServlet......");
		}		
	}
}

验证码输入正确时:
在这里插入图片描述
在这里插入图片描述

验证码输入有误时:
在这里插入图片描述
在这里插入图片描述

注:

如有中文乱码问题,请查看https://blog.csdn.net/Rlynn/article/details/117035838

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值