JSP生成验证码

None.gif<%@ page contentType="image/jpeg"
None.gif    
import="java.awt.*,java.awt.image.*,java.util.*,javax.imageio.*"
None.gif    pageEncoding
="gb2312"%>
ExpandedBlockStart.gifContractedBlock.gif
<%!Color getRandColor(int fc, int bc) dot.gif{//给定范围获得随机颜色   
InBlock.gif
        Random random = new Random();
InBlock.gif        
if (fc > 255)
InBlock.gif            fc 
= 255;
InBlock.gif        
if (bc > 255)
InBlock.gif            bc 
= 255;
InBlock.gif        
int r = fc + random.nextInt(bc - fc);
InBlock.gif        
int g = fc + random.nextInt(bc - fc);
InBlock.gif        
int b = fc + random.nextInt(bc - fc);
InBlock.gif        
return new Color(r, g, b);
ExpandedBlockEnd.gif    }
%>
None.gif
<%
None.gif    
//设置页面缓存   
None.gif
    response.setHeader("Pragma""No-cache");
None.gif    response.setHeader(
"Cache-Control""no-cache");
None.gif    response.setDateHeader(
"Expires"0);
None.gif    
// 在内存中创建图象   
None.gif
    int width = 60, height = 20;
None.gif    BufferedImage image 
= new BufferedImage(width, height,
None.gif            BufferedImage.TYPE_INT_RGB);
None.gif    
// 获取图形上下文   
None.gif
    Graphics g = image.getGraphics();
None.gif    
//生成随机类   
None.gif
    Random random = new Random();
None.gif    
// 设定背景色   
None.gif
    g.setColor(getRandColor(200250));
None.gif    g.fillRect(
00, width, height);
None.gif    
//设定字体   
None.gif
    g.setFont(new Font("Times New Roman", Font.PLAIN, 18));  
None.gif    
// 随机产生155条干扰线,使图象中的认证码不易被其它程序探测到   
None.gif
    g.setColor(getRandColor(160200));
ExpandedBlockStart.gifContractedBlock.gif    
for (int i = 0; i < 155; i++dot.gif{
InBlock.gif        
int x = random.nextInt(width);
InBlock.gif        
int y = random.nextInt(height);
InBlock.gif        
int xl = random.nextInt(12);
InBlock.gif        
int yl = random.nextInt(12);
InBlock.gif        g.drawLine(x, y, x 
+ xl, y + yl);
ExpandedBlockEnd.gif    }

None.gif    
// 取随机产生的认证码(4位数字)   
None.gif
    String sRand = "";
ExpandedBlockStart.gifContractedBlock.gif    
for (int i = 0; i < 4; i++dot.gif{
InBlock.gif        String rand 
= String.valueOf(random.nextInt(10));
InBlock.gif        sRand 
+= rand;
InBlock.gif        
// 将认证码显示到图象中   
InBlock.gif
        g.setCor(new Color(20 + random.nextInt(110), 20 + random
InBlock.gif        .nextInt(
110), 20 + random.nextInt(110)));
InBlock.gif        
//调用函数出来的颜色相同,可能是因为种子太接近,所以只能直接生成   
InBlock.gif
        g.drawString(rand, 13 * i + 616);
ExpandedBlockEnd.gif    }

None.gif    
// 将认证码存入SESSION   
None.gif
    session.setAttribute("rand", sRand);
None.gif    
// 图象生效   
None.gif
    g.dispose();
None.gif    
// 输出图象到页面   
None.gif
    ImageIO.write(image, "JPEG", response.getOutputStream());
None.gif
%>
None.gif
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值