java web中图形验证码的生成(英文和数字混合的验证码)

  • 效果

  • 技术要点

       在此项目中创建了CheckCode类,此类继承了HttpServlet。在此CheckCode类中定义了public Color getRandColor(int s, int e) 方法用于随机返回以Color对象(java.awt.Color)。接下来重写了service函数,此函数的作用是生成BufferedImage对象,并在此对象转型为Graphics对象,并绘制矩形,并设置颜色和字体等。然后将Graphics对象转型为Graphics2D对象,通过设置AffineTransform对象添加缩放和旋转方法。并通过setTransform()方法添加到Graphics2D对象。最后通过Graphics对象调用drawString()写入字符。把生成的验证码保存到Session中,调用ImageIO.write(image, "JPEG", response.getOutputStream());函数将BufferedImage对象写入JSP内置对象out中,out对象通过response.getOutputStream()来获取。

  • 项目结构

  • 要点注意

  1. 定义servlet时需要配置,web.xml文件。
    <servlet>
		<servlet-name>CheckCode</servlet-name>
		<servlet-class>com.CheckCode</servlet-class>
	</servlet>
	<servlet-mapping>
	    <servlet-name>CheckCode</servlet-name>
	    <url-pattern>/CheckCode</url-pattern>
 	 </servlet-mapping>

    2. 在index.jsp文件第51行,如下所示:

<td width="59%" style="padding-top:4px"><img src="CheckCode" id="createCheckCode"><a href="#"onClick="myReload()" >&nbsp;看不清?换一个</a></td>

       其中img标签是显示 验证码图片,而其属性src为CheckCode(原因是在web.xml中配置中<url-pattern>/CheckCode</url-pattern>),而当点击“看不清?换一个”时调用myReload()函数,myReload()函数的主要作用是在src路径加入时间参数,目的是当src路径不变时,img标签始终调用缓存资源,当src路径改变时,才调用servlet中service来响应重新生成验证码。

  • 关键代码

CheckCode.java代码如下:

package com;

import java.awt.*;
import java.awt.geom.*;
import java.awt.image.BufferedImage;
import java.io.File;
import java.io.FileOutputStream;
import java.io.IOException;
import java.util.Random;

import javax.imageio.ImageIO;
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 CheckCode extends HttpServlet {
	public CheckCode() {
		super();
	}

	public void destroy() {
		super.destroy(); 
	}

	public void init() throws ServletException {
		super.init();
	}

	// 获取随机颜色
	public Color getRandColor(int s, int e) {
		Random random = new Random();
		if (s > 255) s = 255;
		if (e > 255) e = 255;
		int r = s + random.nextInt(e - s);		//随机生成RGB颜色中的r值
		int g = s + random.nextInt(e - s);		//随机生成RGB颜色中的g值
		int b = s + random.nextInt(e - s);		//随机生成RGB颜色中的b值
		return new Color(r, g, b);
	}

	public void service(HttpServletRequest request, HttpServletResponse response)
			throws ServletException, IOException {
		//禁用缓存
		response.setHeader("Pragma", "No-cache");
		response.setHeader("Cache-Control", "No-cache");
		response.setDateHeader("Expires", 0);
		// 指定生成的响应是图片,设置发送到客户端的响应的内容类型
		response.setContentType("image/jpeg");
		//指定验证码的宽度
		int width = 86;       							
		//指定验证码的高度
		int height = 22;        							
		BufferedImage image = new BufferedImage(width, height, BufferedImage.TYPE_INT_RGB);
		//获取Graphics类的对象
		Graphics g = image.getGraphics();    					
		Graphics2D g2d = (Graphics2D) g;
		//实例化一个Random对象
		Random random = new Random();		
		//通过Font构造字体
		Font mFont = new Font("黑体", Font.BOLD, 17);		
		//设置颜色
		g.setColor(getRandColor(200, 250)); 		
		//绘制验证码背景
		g.fillRect(0, 0, width, height);    
		//设置字体
		g.setFont(mFont);				
		//设置颜色
		g.setColor(getRandColor(180, 200));		
		// 画随机的线条,可有可无
		/*for (int i = 0; i < 100; i++) {
			//生成起始点x轴的坐标
			int x = random.nextInt(width - 1);	
			//生成起始点y轴的坐标
			int y = random.nextInt(height - 1);	
			//生成结束点x轴的坐标
			int x1 = random.nextInt(6) + 1;	
			//生成结束点y轴的坐标
			int y1 = random.nextInt(12) + 1;	
			BasicStroke bs = new BasicStroke(2f, BasicStroke.CAP_BUTT,BasicStroke.JOIN_BEVEL);
			Line2D line = new Line2D.Double(x, y, x + x1, y + y1);
			g2d.setStroke(bs);
			g2d.draw(line);     //绘制直线
		}*/
		String sRand = "";
		// 输出随机的验证文字
		String ctmp = "";
		int itmp = 0;
		for (int i = 0; i < 4; i++) {
			if((random.nextInt(2)+1)==1){
				// 生成0~9的数字(ascll码)
				itmp = random.nextInt(10) + 48; 
				ctmp = String.valueOf((char) itmp);
			}else{
				 // 生成A~Z的字母(ascll码)
				itmp = random.nextInt(26) + 65;
				ctmp = String.valueOf((char) itmp);
			}
			sRand += ctmp;
			Color color = new Color(20 + random.nextInt(110), 20 + random.nextInt(110), 20 + random.nextInt(110));
			g.setColor(color);		//设置文字颜色
			/** **随机缩放文字并将文字旋转指定角度* */
			// 将文字旋转指定角度
			Graphics2D g2d_word = (Graphics2D) g;
			AffineTransform trans = new AffineTransform();
			trans.rotate(random.nextInt(45) * 3.14 / 180, 15 * i + 8, 7);
			// 缩放文字
			float scaleSize = random.nextFloat() +0.8f;
			if (scaleSize > 1f)	{
				scaleSize = 1f;
			}
			//缩放
			trans.scale(scaleSize, scaleSize);
			g2d_word.setTransform(trans);
			/** ********************* */
			g.drawString(ctmp, 15 * i + 18, 14);

		}
		// 将生成的验证码保存到Session中
		HttpSession session = request.getSession(true);
		session.setAttribute("randCheckCode", sRand);
		//处理此图形上下文并释放其正在使用的任何系统资源。 
		g.dispose();
		ImageIO.write(image, "JPEG", response.getOutputStream());
		//保存图片 JPEG表示保存格式
		//ImageIO.write(image,"JPEG",new FileOutputStream("D:\\a.jpg"));
	}

}
  • 项目下载

本项目为Eclipse中的Dynamic Web Project,需要用Eclipse打开,点我下载项目

发布了46 篇原创文章 · 获赞 48 · 访问量 3万+

猜你喜欢

转载自blog.csdn.net/qq_39559641/article/details/98029015