使用JSP生成验证码

使用JSP生成验证码

在开发中验证码是比较常用到有效防止这种问题对某一个特定注册用户用特定程序暴力破解方式进行不断的登陆尝试的方式。
此演示程序包括三个文件:
1.index.jsp:登录页面
2.image.jsp:生成验证码图片页面
3.result.jsp:结果页面
 
1.index.jsp:登录页面

<%@page contentType="text/html;charset=UTF-8" pageEncoding="UTF-8"%>
<!DOCTYPE html>

<html><body>     
<form method=post action="result.jsp">     
<input type=text name=input maxlength=4>     
<img border=0 src="image.jsp">     
<input type="submit" value="submit">     
</form>
</body>
</html> 

2.image.jsp:生成验证码图片页面
 

<%@ page contentType="image/JPEG"  import="java.awt.*,java.awt.image.*,java.util.*,javax.imageio.*"  pageEncoding="GBK"%>

 
<%!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 < 100; 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("code", sRand);  
 
    // 图象生效  
    g.dispose();  
 
    // 输出图象到页面  
    ImageIO.write(image, "JPEG", response.getOutputStream());  
%> 

 
 
3 result.jsp
 
 

<%@page contentType="text/html;charset=UTF-8" pageEncoding="UTF-8"%>
<!DOCTYPE html>
<html><body> 

<%  
    response.setContentType( "text/html;charset=utf-8 ");//设置响应的字符集
    request.setCharacterEncoding("utf-8");//设置请求的字符集

    String input=request.getParameter("input");  
    String code=(String)session.getAttribute("code");      
    if(input.equals(code)){  
        out.println("验证成功!");  
    }else{  
        out.println("验证失败!");  
    }  
%> 
</body>

</html> 

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值