日期:2014-05-18  浏览次数:20657 次

JSP验证码问题
在使用验证码的时候碰到以下问题:A页面使用验证码,显示为1234,再重新打开B页面(B页面也使用了验证码,显示为2341),当回到A页面输入验证码的时候,输入1234肯定出错,因为验证码在B页面中刷新了,但是有些用户不清楚这个原理,肯定会输入1234,提示验证码错误,不知道如何避免这种错误???也就是说在A页面输入1234验证成功,不管打开的新页面是否使用了验证码

代码如下:
<%@   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.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( "Times   New   Roman ",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());


%>