`
风远阁
  • 浏览: 39519 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

验证码的学习与实现

阅读更多

首先编写生成验证码数字以及图片的类RandomNumUtil.java。具体代码如下:

import java.awt.Color;
import java.awt.Font;
import java.awt.Graphics;
import java.awt.image.BufferedImage;
import java.io.ByteArrayInputStream;
import java.io.ByteArrayOutputStream;
import java.util.Random;
import javax.imageio.ImageIO;
import javax.imageio.stream.ImageOutputStream;

public class RandomNumUtil {
	/*
	 * ByteArrayInputStream包含一个内部缓冲,存储从流中读取的字节。 
	 */
	private ByteArrayInputStream image;// 图像
	private String str;// 验证码

	private RandomNumUtil() {
		init();// 初始化各属性
	}

	public ByteArrayInputStream getImage() {
		return this.image;
	}

	public String getString() {
		return this.str;
	}

	private void init() {
		// 在内存中创建图象
		int width = 86, height = 21;
		BufferedImage image = new BufferedImage(width, height,
				BufferedImage.TYPE_INT_RGB);
		// 获取图形上下文
		Graphics g = image.getGraphics();
		// 生成随机类
		Random random = new Random();
		// 设定背景色
		g.setColor(getRandColor(200, 250));
		g.fillRect(0, 0, width, height);
		// 设定字体
		g.setFont(new Font("Times New Roman", Font.PLAIN, 18));
		// 随机产生155条干扰线,使图象中的认证码不易被其它程序探测到
		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);
		}
		// 取随机产生的认证码(6位数字)
		String sRand = "";
		for (int i = 0; i < 6; i++) {
			String rand = String.valueOf(random.nextInt(10));
			sRand += rand;
			// 将认证码显示到图象中
			g.setColor(new Color(20 + random.nextInt(110), 20 + random
					.nextInt(110), 20 + random.nextInt(110)));
			// 调用函数出来的颜色相同,可能是因为种子太接近,所以只能直接生成
			g.drawString(rand, 13 * i + 6, 16);
		}
		// 赋值验证码
		this.str = sRand;

		// 图象生效
		g.dispose();
		ByteArrayInputStream input = null;
		ByteArrayOutputStream output = new ByteArrayOutputStream();
		try {
			ImageOutputStream imageOut = ImageIO
					.createImageOutputStream(output);
			ImageIO.write(image, "JPEG", imageOut);
			imageOut.close();
			input = new ByteArrayInputStream(output.toByteArray());
		} catch (Exception e) {
			System.out.println("验证码图片产生出现错误:" + e.toString());
		}

		this.image = input;/* 赋值图像 */
	}

	/*
	 * 给定范围获得随机颜色
	 */
	private 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);
	}
}

 然后,创建具体的控制类RandomAction.java,具体代码如下:

 

import java.io.ByteArrayInputStream;
import com.opensymphony.xwork2.ActionContext;
import com.opensymphony.xwork2.ActionSupport;
import com.softeye.util.RandomNumUtil;

public class RandomAction extends ActionSupport {
	private ByteArrayInputStream inputStream;

	public String execute() throws Exception {
		RandomNumUtil rdnu = new RandomNumUtil();
		this.setInputStream(rdnu.getImage());// 取得带有随机字符串的图片
		ActionContext.getContext().getSession().put("random", rdnu.getString());// 取得随机字符串放入HttpSession
		return SUCCESS;
	}

	public void setInputStream(ByteArrayInputStream inputStream) {
		this.inputStream = inputStream;
	}

	public ByteArrayInputStream getInputStream() {
		return inputStream;
	}
}

 再然后,对struts.xml中RandomAction.进行配置,具体代码如下:

<!-- Random验证码 -->
<action name="rand" class="com.softeye.action.login.RandomAction">   
      <result type="stream">   
           <param name="contentType">image/jpeg</param>   
           <param name="inputName">inputStream</param>   
       </result>
 </action>

 

最后,在注册页面添加验证码功能:
其一:在head标签内添加JavaScript,具体代码如下:

<script type="text/javascript">    
function changeValidateCode(obj) {    
//获取当前的时间作为参数,无具体意义    
var timenow = new Date().getTime();    
//每次请求需要一个不同的参数,否则可能会返回同样的验证码    
//这和浏览器的缓存机制有关系,也可以把页面设置为不缓存,这样就不用这个参数了。    
obj.src="<%=path%>/user/rand.action?d="+timenow;    
}    
</script> 

 其二,在页面相应位置设计验证码,例如:

 <tr>
         <th>
                <span>*</span>验证码:
          </th>
          <td>
                 <input id="" name="rand" value="" type="text" />
          <span><img src="<%=path %>/user/rand.action"  onclick="changeValsidateCode(this)" title="点击图片刷新验证码"/>
            </span>
          </td>
 </tr>

 

至此,一个防止批量注册的验证码功能就实现了。 

2
0
分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics