生成验证吗码

验证码区域:
<div><div class="ContentLeft2"><span class="word_gray424242"><bean:message key="web.contractus.vericode"/></span> <span class="word_red">*</span></div>
<div class="ContentRight2">
<input class="text" style="width:135px;" type="text" name="authcode">
  <img src="<c:out value="${ctx}" />/commons/checkImage.jsp" align="absmiddle" width="60">
</div>
<div class="divspace"></div>
</div>

checkImage.jsp:

<%@ page contentType="image/jpeg"
import="java.awt.*,java.awt.image.*,java.util.*,javax.imageio.*"%>
<%!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);
}
%>
<%
response.flushBuffer();
out.clear();//这句针对resin服务器,如果是tomacat可以不要这句
//设置页面不缓存

response.setHeader("Pragma", "No-cache");
response.setHeader("Cache-Control", "no-cache");
response.setDateHeader("Expires", 0);

//在内存中创建图象
int width = 60, height = 20;
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("Comic Sans MS", Font.PLAIN, 18));

//画边框

//g.setColor(new Color());
//g.drawRect(0,0,width-1,height-1);

//随机产生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);
}

// 取随机产生的认证码(4位数字)
String sRand = "";
for (int i = 0; i < 4; 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);
}

//将认证码存入SESSION
session.setAttribute("rand", sRand);

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

// 输出图象到页面

ImageIO.write(image, "JPEG", response.getOutputStream());
%>


3 代码验证部分:
String authcode = request.getParameter("authcode");
String _authSnCode = (String) session.getAttribute("rand");
if (!authcode.equals(_authSnCode))
{

//验证码错误
request.setAttribute("messages", "user.login.chkRand");
//本地验证登录失败
return mapping.findForward("contructUs");

}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值