Chinaunix首页 | 论坛 | 博客
  • 博客访问: 1612884
  • 博文数量: 585
  • 博客积分: 14610
  • 博客等级: 上将
  • 技术积分: 7402
  • 用 户 组: 普通用户
  • 注册时间: 2008-05-15 10:52
文章存档

2013年(5)

2012年(214)

2011年(56)

2010年(66)

2009年(44)

2008年(200)

分类:

2008-05-25 03:45:43




JSP实现的验证码

image.jsp

<%@ page contentType="image/jpeg"%>
<%@ page import="java.awt.*"%>
<%@ page import="java.awt.image.*"%>
<%@ page import="java.util.*"%>
<%@ page import="javax.imageio.*"%>
<%
 //在内存中创建图象
 int iWidth=130,iHeight=18;
 BufferedImage image=new BufferedImage(iWidth,iHeight,BufferedImage.TYPE_INT_RGB);
 //获取图形上下文
 Graphics g=image.getGraphics();
 //设定背景色
 g.setColor(Color.white);
 g.fillRect(0,0,iWidth,iHeight);
 //画边框
 g.setColor(Color.black);
 g.drawRect(0,0,iWidth-1,iHeight-1);
 //取随机产生的认证码(4位数字)
 String rand=request.getParameter("Rand");
 rand=rand.substring(0,rand.indexOf("."));
 switch(rand.length())
 {
  case 1:rand="000"+rand;break;
  case 2:rand="00"+rand;break;
  case 3:rand="0"+rand;break;
  default:rand=rand.substring(0,4);break;
 }
 //将认证码存入SESSION
 session.setAttribute("Rand",rand);
 //将认证码显示到图象中
 g.setColor(Color.black);
 g.setFont(new Font("Times New Roman",Font.PLAIN,18));
 g.drawString(rand,10,15);
 //随机产生88个干扰点,使图象中的认证码不易被其它程序探测到
 Random random=new Random();
 for(int iIndex=0;iIndex<88;iIndex++)
 {
  int x=random.nextInt(iWidth);
  int y=random.nextInt(iHeight);
  g.drawLine(x,y,x,y);
 }
 //图象生效
 g.dispose();
 //输出图象到页面
 ImageIO.write(image,"JPEG",response.getOutputStream());
%>

 

输出时应用验证码



     输认证码: 

 

登录认证:

 String Rand=request.getParameter("Rand");
 String strRand=(String)session.getAttribute("Rand");
 if(!strRand.equals(Rand))
 {
  //未通过;
 }

阅读(560) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~