简简单单实现验证码

实现如下图的验证码效果:


过程很简单:

1,建一个jsp

<%@page import="javax.imageio.ImageIO"%>
<%@page import="java.awt.Transparency"%>
<%@page import="java.awt.AlphaComposite"%>
<%@page import="java.awt.Font"%>
<%@page import="java.io.OutputStream"%>
<%@page import="com.sun.image.codec.jpeg.JPEGImageEncoder"%>
<%@page import="com.sun.image.codec.jpeg.JPEGCodec"%>
<%@page import="java.awt.Graphics2D"%>
<%@page import="java.awt.image.BufferedImage"%>
<%@page import="com.xxwan.common.utils.SessionKeys"%>
<%@page import="java.awt.Color"%>
<%@ page language="java" import="java.util.*" pageEncoding="utf-8"%>

<%!
	public static final char chars [] =  new char[]{'2','3','4','5','6','7','8','9','A','B','C','D','E','F','G','H','K','M','N','P','Q','R','S','T','W','Y'};
	
	public static Random random = new Random();
	public static Color getRandomColor() {
		return new Color(random.nextInt(255) & 0x00ffffff ,random.nextInt(255),random.nextInt(255));
	}

	public static Color getReverseColor(Color c) {
		return new Color(255- c.getRed(),255-c.getBlue(),255-c.getGreen());
	}
	
	public static final int [] colorRgbs = new int[] {0x00123456,0x00654321,0x00383838,0x000000ff,0x00ff0000,0x00000000,0x00ff8800,0x00c000c0,0x00808080,0x006b51c7};
	
	public static String getRandomString(Graphics2D g){
		StringBuffer sb = new StringBuffer();
		int j = 0;
		
		for(int i = 0; i < 4 ; i++) {
			char c  = chars[random.nextInt(chars.length)];
			String s = new String(new char[]{c});
			if(random.nextInt(20) % 2 == 0) s = s.toLowerCase();
			sb.append(s);
			g.setColor(new Color(colorRgbs[random.nextInt(colorRgbs.length)]));
			g.drawString(s,(25 + j),35 + random.nextInt(5));
			j += 20;
		}
		return sb.toString();
	}
 %>

<%
	
	response.setContentType("image/jpeg");
	response.setHeader("Pragma","No-cache");
	response.setHeader("Cache-Control","no-cache");
	response.setDateHeader("Expires",0);
	
	
	OutputStream output = response.getOutputStream();
	Color c = getRandomColor();
	int width = 131, height = 53;
	BufferedImage bi = new BufferedImage(width,height,BufferedImage.TYPE_INT_RGB);
	for(int i = 0; i < width; ++i) {
       for(int j = 0; j < height; ++j) {           
             bi.setRGB(i, j,0x00ffffff);
       }
    }
	Graphics2D g = bi.createGraphics();
	g.setFont(new Font("Times new Roman",Font.PLAIN,30));
	g.setColor(c);
	for(int i=0;i<30;i++) g.drawRect(random.nextInt(width), random.nextInt(height),1,1);
	String code = getRandomString(g);
	session.setAttribute(SessionKeys.REGISTER_CODE, code);
	g.dispose();
	ImageIO.write(bi, "JPEG", output);
	output.flush();
	output.close();
	output = null;
	response.flushBuffer();
	out.clear();
	out = pageContext.pushBody();
%>

2,用到验证码的页面加入标签:

<img src="controller拦截的路径<%= new Date() %>" title="点击刷新" οnclick="refreshI(this);"/>

3,(这写得够白痴了)上面的js也给出来

function refreshI(srcE) {
	srcE.setAttribute("src","controller拦截的路径?" + new Date());
}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值