java 验证码

1.Servlet生成验证码图片

Java代码 复制代码
  1. package com.logcd.servlet;   
  2.   
  3. import java.awt.Color;   
  4. import java.awt.Font;   
  5. import java.awt.Graphics2D;   
  6. import java.awt.image.BufferedImage;   
  7. import java.util.Random;   
  8. import javax.imageio.ImageIO;   
  9. import javax.servlet.*;   
  10. import java.io.*;   
  11. import javax.servlet.http.*;   
  12. import javax.servlet.ServletException;   
  13. import javax.servlet.http.HttpServlet;   
  14. import javax.servlet.http.HttpServletRequest;   
  15. import javax.servlet.http.HttpServletResponse;   
  16.   
  17. @SuppressWarnings("serial")   
  18. public class RandomCode extends HttpServlet {   
  19.   
  20.     public void doGet(HttpServletRequest request, HttpServletResponse response)   
  21.             throws ServletException, IOException {   
  22.   
  23.         this.doPost(request, response);   
  24.     }   
  25.   
  26.     public void doPost(HttpServletRequest request, HttpServletResponse response)   
  27.             throws ServletException, IOException {   
  28.   
  29.         // 验证码图片的宽度。   
  30.         int width = 70;   
  31.         // 验证码图片的高度。   
  32.         int height = 30;   
  33.         BufferedImage buffImg = new BufferedImage(width, height,   
  34.                 BufferedImage.TYPE_INT_RGB);   
  35.         Graphics2D g = buffImg.createGraphics();   
  36.   
  37.         // 创建一个随机数生成器类。   
  38.         Random random = new Random();   
  39.   
  40.         // 设定图像背景色(因为是做背景,所以偏淡)   
  41.         g.setColor(getRandColor(200250));   
  42.         g.fillRect(00, width, height);   
  43.         // 创建字体,字体的大小应该根据图片的高度来定。   
  44.         Font font = new Font("Times New Roman", Font.HANGING_BASELINE, 28);   
  45.         // 设置字体。   
  46.         g.setFont(font);   
  47.   
  48.         // 画边框。   
  49.         g.setColor(Color.BLACK);   
  50.         g.drawRect(00, width - 1, height - 1);   
  51.         // 随机产生155条干扰线,使图象中的认证码不易被其它程序探测到。   
  52.         //g.setColor(Color.GRAY);   
  53.         g.setColor(getRandColor(160,200));   
  54.         for (int i = 0; i < 155; i++) {   
  55.             int x = random.nextInt(width);   
  56.             int y = random.nextInt(height);   
  57.             int xl = random.nextInt(12);   
  58.             int yl = random.nextInt(12);   
  59.             g.drawLine(x, y, x + xl, y + yl);   
  60.         }   
  61.   
  62.         // randomCode用于保存随机产生的验证码,以便用户登录后进行验证。   
  63.         StringBuffer randomCode = new StringBuffer();   
  64.   
  65.         // 设置默认生成4个验证码   
  66.         int length = 4;   
  67.         // 设置备选验证码:包括"a-z"和数字"0-9"   
  68.         String base = "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789";   
  69.   
  70.         int size = base.length();   
  71.   
  72.         // 随机产生4位数字的验证码。   
  73.         for (int i = 0; i < length; i++) {   
  74.             // 得到随机产生的验证码数字。   
  75.             int start = random.nextInt(size);   
  76.             String strRand = base.substring(start, start + 1);   
  77.   
  78.             // 用随机产生的颜色将验证码绘制到图像中。   
  79.             // 生成随机颜色(因为是做前景,所以偏深)   
  80.             //g.setColor(getRandColor(1, 100));   
  81.                
  82.             //调用函数出来的颜色相同,可能是因为种子太接近,所以只能直接生成   
  83.             g.setColor(new Color(20+random.nextInt(110),20+random.nextInt(110),20+random.nextInt(110)));   
  84.   
  85.             g.drawString(strRand, 15 * i + 624);   
  86.   
  87.             // 将产生的四个随机数组合在一起。   
  88.             randomCode.append(strRand);   
  89.         }   
  90.         // 将四位数字的验证码保存到Session中。   
  91.         HttpSession session = request.getSession();   
  92.         session.setAttribute("rand", randomCode.toString());   
  93.   
  94.         //图象生效   
  95.         g.dispose();   
  96.   
  97.         // 禁止图像缓存。   
  98.         response.setHeader("Pragma""no-cache");   
  99.         response.setHeader("Cache-Control""no-cache");   
  100.         response.setDateHeader("Expires"0);   
  101.   
  102.         response.setContentType("image/jpeg");   
  103.   
  104.         // 将图像输出到Servlet输出流中。   
  105.         ServletOutputStream sos = response.getOutputStream();   
  106.         ImageIO.write(buffImg, "jpeg", sos);   
  107.         sos.flush();   
  108.         sos.close();   
  109.   
  110.     }   
  111.   
  112.     Color getRandColor(int fc, int bc) {// 给定范围获得随机颜色   
  113.         Random random = new Random();   
  114.         if (fc > 255)   
  115.             fc = 255;   
  116.         if (bc > 255)   
  117.             bc = 255;   
  118.         int r = fc + random.nextInt(bc - fc);   
  119.         int g = fc + random.nextInt(bc - fc);   
  120.         int b = fc + random.nextInt(bc - fc);   
  121.         return new Color(r, g, b);   
  122.     }   
  123.   
  124. }  
package com.logcd.servlet;

import java.awt.Color;
import java.awt.Font;
import java.awt.Graphics2D;
import java.awt.image.BufferedImage;
import java.util.Random;
import javax.imageio.ImageIO;
import javax.servlet.*;
import java.io.*;
import javax.servlet.http.*;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

@SuppressWarnings("serial")
public class RandomCode extends HttpServlet {

	public void doGet(HttpServletRequest request, HttpServletResponse response)
			throws ServletException, IOException {

		this.doPost(request, response);
	}

	public void doPost(HttpServletRequest request, HttpServletResponse response)
			throws ServletException, IOException {

		// 验证码图片的宽度。
		int width = 70;
		// 验证码图片的高度。
		int height = 30;
		BufferedImage buffImg = new BufferedImage(width, height,
				BufferedImage.TYPE_INT_RGB);
		Graphics2D g = buffImg.createGraphics();

		// 创建一个随机数生成器类。
		Random random = new Random();

		// 设定图像背景色(因为是做背景,所以偏淡)
		g.setColor(getRandColor(200, 250));
		g.fillRect(0, 0, width, height);
		// 创建字体,字体的大小应该根据图片的高度来定。
		Font font = new Font("Times New Roman", Font.HANGING_BASELINE, 28);
		// 设置字体。
		g.setFont(font);

		// 画边框。
		g.setColor(Color.BLACK);
		g.drawRect(0, 0, width - 1, height - 1);
		// 随机产生155条干扰线,使图象中的认证码不易被其它程序探测到。
		//g.setColor(Color.GRAY);
		g.setColor(getRandColor(160,200));
		for (int i = 0; i < 155; i++) {
			int x = random.nextInt(width);
			int y = random.nextInt(height);
			int xl = random.nextInt(12);
			int yl = random.nextInt(12);
			g.drawLine(x, y, x + xl, y + yl);
		}

		// randomCode用于保存随机产生的验证码,以便用户登录后进行验证。
		StringBuffer randomCode = new StringBuffer();

		// 设置默认生成4个验证码
		int length = 4;
		// 设置备选验证码:包括"a-z"和数字"0-9"
		String base = "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789";

		int size = base.length();

		// 随机产生4位数字的验证码。
		for (int i = 0; i < length; i++) {
			// 得到随机产生的验证码数字。
			int start = random.nextInt(size);
			String strRand = base.substring(start, start + 1);

			// 用随机产生的颜色将验证码绘制到图像中。
			// 生成随机颜色(因为是做前景,所以偏深)
			//g.setColor(getRandColor(1, 100));
			
			//调用函数出来的颜色相同,可能是因为种子太接近,所以只能直接生成
			g.setColor(new Color(20+random.nextInt(110),20+random.nextInt(110),20+random.nextInt(110)));

			g.drawString(strRand, 15 * i + 6, 24);

			// 将产生的四个随机数组合在一起。
			randomCode.append(strRand);
		}
		// 将四位数字的验证码保存到Session中。
		HttpSession session = request.getSession();
		session.setAttribute("rand", randomCode.toString());

		//图象生效
        g.dispose();

		// 禁止图像缓存。
		response.setHeader("Pragma", "no-cache");
		response.setHeader("Cache-Control", "no-cache");
		response.setDateHeader("Expires", 0);

		response.setContentType("image/jpeg");

		// 将图像输出到Servlet输出流中。
		ServletOutputStream sos = response.getOutputStream();
		ImageIO.write(buffImg, "jpeg", sos);
		sos.flush();
		sos.close();

	}

	Color getRandColor(int fc, int bc) {// 给定范围获得随机颜色
		Random random = new Random();
		if (fc > 255)
			fc = 255;
		if (bc > 255)
			bc = 255;
		int r = fc + random.nextInt(bc - fc);
		int g = fc + random.nextInt(bc - fc);
		int b = fc + random.nextInt(bc - fc);
		return new Color(r, g, b);
	}

}


2.配置

Xml代码 复制代码
  1. <servlet>  
  2.     <servlet-name>RandomCode</servlet-name>  
  3.     <servlet-class>com.logcd.servlet.RandomCode</servlet-class>  
  4. </servlet>  
  5. <servlet-mapping>  
  6.     <servlet-name>RandomCode</servlet-name>  
  7.     <url-pattern>/randomCode</url-pattern>  
  8. </servlet-mapping>  
    <servlet>
        <servlet-name>RandomCode</servlet-name>
        <servlet-class>com.logcd.servlet.RandomCode</servlet-class>
    </servlet>
    <servlet-mapping>
        <servlet-name>RandomCode</servlet-name>
        <url-pattern>/randomCode</url-pattern>
    </servlet-mapping>


3.调用

Html代码 复制代码
  1. <meta http-equiv="Content-Type" content="text/html; charset=gb2312" />  
  2. <meta http-equiv="pragma" content="no-cache"/>  
  3. <meta http-equiv="cache-control" content="no-cache"/>  
  4. <meta http-equiv="expires" content="0"/>  
  5.   
  6. <iframe src="http://127.0.0.1/js_test/randomCode" id="codeFrame" name="codeFrame" frameborder="no" border="0" marginwidth="0"  
  7.      marginheight="0" scrolling="no" allowtransparency="yes" height="35" width="102"></iframe>  
  8.      <a href="javascript:void(0);" onclick="refreshCode();">看不清,换一张</a>  
  9.     <br>    
  10.     <span id="codeImg"><img border=0 src="randomCode"></span>  
  11.     <a href="javascript:void(0);" onclick="reloadCode()">看不清,再换一张</a>  
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
<meta http-equiv="pragma" content="no-cache"/>
<meta http-equiv="cache-control" content="no-cache"/>
<meta http-equiv="expires" content="0"/>

<iframe src="http://127.0.0.1/js_test/randomCode" id="codeFrame" name="codeFrame" frameborder="no" border="0" marginwidth="0"
	 marginheight="0" scrolling="no" allowtransparency="yes" height="35" width="102"></iframe>
	 <a href="javascript:void(0);" οnclick="refreshCode();">看不清,换一张</a>
	<br> 
	<span id="codeImg"><img border=0 src="randomCode"></span>
	<a href="javascript:void(0);" οnclick="reloadCode()">看不清,再换一张</a>

 

Js代码 复制代码
  1. function $(id){   
  2.     return document.getElementById(id);   
  3. }   
  4.   
  5. /**刷新iframe**/  
  6. function refreshCode(){   
  7.     window.frames["codeFrame"].location.reload();   
  8. }   
  9.   
  10. /**替换图片**/  
  11. function reloadCode(){   
  12.     $("codeImg").innerHTML = "<img border=0 src='randomCode'>";   
  13. }  
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值