servlet简单的验证码登录验证

package com.bjsxt.check;

import java.awt.Color;
import java.awt.Font;
import java.awt.Graphics;
import java.awt.image.BufferedImage;
import java.io.ByteArrayOutputStream;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.OutputStream;
import java.io.PrintWriter;
import java.util.Random;

import javax.imageio.ImageIO;<pre name="code" class="java">package com.bjsxt.check;

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;

public class Check extends HttpServlet {

	public void doPost(HttpServletRequest request, HttpServletResponse response)
			throws ServletException, IOException {
		
		String checkCode = request.getParameter("checkCode");
		String name = request.getParameter("uname");
		String pwd = request.getParameter("pwd");
		
		String checkCode1 = (String) request.getSession().getAttribute("checkCode");
		//验证生成的验证码和用户输入的验证码是否一致,一致则登陆成功,否则失败
		if(checkCode!=null&&checkCode.equals(checkCode1)){
			request.getRequestDispatcher("/index.jsp").forward(request, response);
		}else{
			request.getRequestDispatcher("/checkcode.jsp").forward(request, response);
		}

	}

}

<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
<%
String path = request.getContextPath();
String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";
%>

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
  <head>
    <base href="<%=basePath%>">
    
    <title>My JSP 'checkcode.jsp' starting page</title>
    
	<meta http-equiv="pragma" content="no-cache">
	<meta http-equiv="cache-control" content="no-cache">
	<meta http-equiv="expires" content="0">    
	<meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
	<meta http-equiv="description" content="This is my page">
	
	<!--
	<link rel="stylesheet" type="text/css" href="styles.css">
	-->
  </head>
  <script type="text/javascript" src="js/jquery-1.9.1.min.js"></script>
  <script type="text/javascript">
  	$(function(){
  		$("#check").click(function(){
  			$("#check").attr("src",null);
  			$("#check").attr("src","/checkcode_03/checkCode?"+Math.random());
  		});
  		$("#change").click(function(){
  			$("#check").attr("src",null);
  			$("#check").attr("src","/checkcode_03/checkCode?"+Math.random());
  			return false;
  		});
  	});
  
  
  </script>
  
  <body>
  	<form action="check" method="post">
  		<table>
  			<tr>
				<th>用户名</th><td><input type="text" value="" name="uname"/></td>			
  			</tr>
  			<tr>
				<th>密码</th><td><input type="password" value="" name="pwd"/></td>			
  			</tr>
  			<tr>
				<th>验证码</th><td><input type="text" value="" name="checkCode"/></td>			
  			</tr>
  			<tr>
				<th colspan="2"><img alt="验证码" src="/checkcode_03/checkCode" id="check"><a href="#" id="change" >看不清,换一张</a></th>			
  			</tr>
  			<tr>
				<th colspan="2"><input type="submit" value="提交"/>     <input type="reset" value="重置"/></th>			
  			</tr>
  		</table>
  	</form>
  </body>
</html>

import java.awt.Color;
import java.awt.Font;
import java.awt.Graphics;
import java.awt.image.BufferedImage;
import java.io.ByteArrayOutputStream;
import java.io.IOException;
import java.util.Random;

import javax.imageio.ImageIO;
import javax.imageio.stream.ImageOutputStreamImpl;
import javax.servlet.ServletException;
import javax.servlet.ServletOutputStream;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;
public class CheckCode extends HttpServlet {
	private static final long serialVersionUID = 1L;
	private static final int WIDTH = 100;
	private static final int HEIGHT = 30;
	private char[] checkCode = new char[4];
	private Random random = new Random();
	// 随机产生二维码字符四个
	public char[] getCheckCode() {
		String str = "abcdefghijklmnopqrstuvwxyz0123456789";
		for (int i = 0; i < 4; i++) {
			int index = random.nextInt(str.length());
			checkCode[i] = str.charAt(index);
			}
		return checkCode;}
	// 设置图片背景
	public void setBackGround(Graphics g) {
		// 设置背景色
		g.setColor(Color.GRAY);
		// 填充背景色
		g.fillRect(0, 0, WIDTH, HEIGHT);
		for (int i = 0; i < 120; i++) {
			// 设置干扰点颜色
			g.setColor(new Color(random.nextInt(255), random.nextInt(255),random.nextInt(255)));
			// 设置干扰点
			g.drawOval(random.nextInt(WIDTH), random.nextInt(HEIGHT), 1, 0);}
		}
	// 将验证码写在图片上
	public void DrawFont(Graphics g, char[] checkCode) {
		for (int i = 0; i < checkCode.length; i++) {
			g.setColor(new Color(random.nextInt(255), random.nextInt(255),random.nextInt(255)));
			g.setFont(new Font(null, Font.ITALIC | Font.BOLD, 30));g.drawString("" + checkCode[i], (int) (Math.random() + 25 * i),(int) (Math.random() * 5 + 27));
			}
		}
	public void doGet(HttpServletRequest request, HttpServletResponse response)throws ServletException, IOException {
		response.setContentType("image/jpeg");HttpSession session = request.getSession();
		BufferedImage image = new BufferedImage(WIDTH, HEIGHT,BufferedImage.TYPE_INT_RGB);
		Graphics g = image.getGraphics();
		char[] checkCode = getCheckCode();
		setBackGround(g);
		DrawFont(g, checkCode);
		g.dispose();
		ByteArrayOutputStream arrayOutputStream = new ByteArrayOutputStream();
		ImageIO.write(image, "JPEG", arrayOutputStream);
		byte[] buf = arrayOutputStream.toByteArray();
		ServletOutputStream sos = response.getOutputStream();
		sos.write(buf);response.setContentLength(buf.length);
		// 关闭各种流释放资源
		arrayOutputStream.close();
		sos.close();
		session.setAttribute("checkCode", new String(checkCode));
		}
	}


 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
实现验证码功能的主要思路是在用户注册或登录时生成一个随机的验证码图片,并将验证码保存在session中。当用户提交表单时,将用户输入的验证码与session中保存的验证码进行比对,如果一致则继续执行,否则提示用户输入错误。 以下是一个使用IDEA和Servlet实现验证码功能的示例代码。 1. 首先,在web.xml中配置servletservlet-mapping: ```xml <servlet> <servlet-name>VerifyCodeServlet</servlet-name> <servlet-class>com.example.VerifyCodeServlet</servlet-class> </servlet> <servlet-mapping> <servlet-name>VerifyCodeServlet</servlet-name> <url-pattern>/verifyCode</url-pattern> </servlet-mapping> ``` 2. 创建一个名为VerifyCodeServletservlet类,实现doGet方法: ```java package com.example; import javax.imageio.ImageIO; import javax.servlet.ServletException; import javax.servlet.annotation.WebServlet; import javax.servlet.http.HttpServlet; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import javax.servlet.http.HttpSession; import java.awt.*; import java.awt.image.BufferedImage; import java.io.IOException; import java.util.Random; @WebServlet("/verifyCode") public class VerifyCodeServlet extends HttpServlet { protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { int width = 100; int height = 30; //创建一个图像缓冲区 BufferedImage image = new BufferedImage(width, height, BufferedImage.TYPE_INT_RGB); //获取Graphics2D Graphics2D g2 = (Graphics2D) image.getGraphics(); //设置背景色 g2.setColor(Color.WHITE); g2.fillRect(0, 0, width, height); //设置字体 g2.setFont(new Font("宋体", Font.BOLD, 20)); //生成随机字符 String verifyCode = generateVerifyCode(); //将验证码保存在session中 HttpSession session = request.getSession(); session.setAttribute("verifyCode", verifyCode); //绘制验证码 Random random = new Random(); for (int i = 0; i < verifyCode.length(); i++) { g2.setColor(new Color(random.nextInt(255), random.nextInt(255), random.nextInt(255))); g2.drawString(String.valueOf(verifyCode.charAt(i)), i * 20 + 10, 20); } //加入干扰线 for (int i = 0; i < 5; i++) { g2.setColor(new Color(random.nextInt(255), random.nextInt(255), random.nextInt(255))); g2.drawLine(random.nextInt(width), random.nextInt(height), random.nextInt(width), random.nextInt(height)); } //输出图像到页面 response.setContentType("image/jpeg"); ImageIO.write(image, "jpeg", response.getOutputStream()); } /** * 生成随机验证码 * * @return */ private String generateVerifyCode() { String chars = "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789"; StringBuilder sb = new StringBuilder(); Random random = new Random(); for (int i = 0; i < 4; i++) { sb.append(chars.charAt(random.nextInt(chars.length()))); } return sb.toString(); } } ``` 3. 在用户注册或登录页面中添加验证码图片和输入框: ```html <form action="login" method="post"> <div> <label for="username">用户名:</label> <input type="text" name="username" id="username"> </div> <div> <label for="password">密码:</label> <input type="password" name="password" id="password"> </div> <div> <label for="verifyCode">验证码:</label> <input type="text" name="verifyCode" id="verifyCode"> <img src="verifyCode" alt="验证码"> </div> <div> <input type="submit" value="登录"> </div> </form> ``` 4. 在用户登录或注册时验证验证码是否正确: ```java protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { //获取用户输入的验证码 String verifyCode = request.getParameter("verifyCode"); //获取session中保存的验证码 HttpSession session = request.getSession(); String sessionVerifyCode = (String) session.getAttribute("verifyCode"); //比对验证码 if (verifyCode.equalsIgnoreCase(sessionVerifyCode)) { //验证码正确,继续执行 } else { //验证码错误,提示用户 } } ``` 以上就是用IDEA和Servlet实现验证码功能的示例代码。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值