带干扰线的验证码

文章来源:http://blog.csdn.net/yuyuyuyuy/article/details/5835583


下面是带干扰线的验证码的.jsp文件,大家一看就知道怎么用了,而不用自己亲自去写了。

      1。显示验证码的页面login.html

<html>
 <head>
 <title>用户登陆页面</title>
 </head>
 
 <body>
 <form action="checkcode.jsp" method="post">
 验证码:<input name="code" type="text" size="15">
 <br><br>
 <img src="code.jsp"/>
 <br>
 &nbsp;&nbsp;&nbsp;&nbsp;<input type="submit" value="登录">
 &nbsp;&nbsp;&nbsp;<input type="reset" value="重填">
 </form>
 </body> 
</html>

 

         2。验证码的生成页面code.jsp

<%@ page language="java" contentType="text/html; charset=GBK" pageEncoding="GBK" 
     import="java.io.*,
          java.util.*,
          com.sun.image.codec.jpeg.*,
          java.awt.*,
          java.awt.image.*"%>


<%
  String s = "";

        int intCount = 0;
        /**
      * 验证码宽度
      */
      int width=100;
     /**
      * 验证码高度
      */
      int height=25;
        /**
      * 验证码字符集
      */
      char[] code=new char[]{
      'A','B','C','D','E','F','G','H','I','J','K','L','M','N','P','Q','R','S','T','U','V','W','X','Y','Z',
      'a','b','c','d','e','f','g','h','i','j','k','l','m','n','p','q','r','s','t','u','v','w','x','y','z',
       '2','3','4','5','6','7','8','9','开','绝','天','地','我','家','吮','光','爱','乐','笑','堂','小','昂'};
     
        /**
         *  创建一个随机数生成器类
         */
        Random random = new Random(); 

       
       // 随机产生codeCount数字的验证码。   
        for (int i = 0; i < 4; i++) {   
            // 得到随机产生的验证码数字。   
            String strRand = String.valueOf(code[random.nextInt(code.length)]);   
        
            // 将产生的四个随机数组合在一起。   
            s=s+strRand;   
        }

        // 保存入session,用于与用户的输入进行比较.
        // 注意比较完之后清除session.

        session.setAttribute("validateCode", s);

        response.setContentType("image/gif");
       

   // 定义图像buffer   
        BufferedImage image = new BufferedImage(width, height,
                BufferedImage.TYPE_INT_RGB);
        Graphics2D gra = image.createGraphics(); 
      // 将图像填充为白色   
        gra.setColor(Color.WHITE);   
        gra.fillRect(0, 0, width, height);   
  
        // 创建字体,字体的大小应该根据图片的高度来定。  
       
       //字体对象构造方法public Font(String familyName,int style,int size)
       // familyName字体名;字体名可以分成两大类:中文字体:宋体、楷体、黑体等;英文字体:Arial、Times New Roman等等;
       // style风格。PLAIN普通字体,BOLD(加粗),ITALIC(斜体),Font.BOLD+ Font.ITALIC(粗斜体)
       //size 大小

       
        Font font = new Font("宋体", Font.BOLD+Font.ITALIC, height-1);//
  
       
        // 设置字体。   
        gra.setFont(font);   
  
  
        // 画边框。   
        gra.setColor(getColor());   
        gra.drawRect(0, 0, width - 1, height - 1); 
   
  
        // 随机产生干扰线,使图象中的认证码不易被其它程序探测到。   
        gra.setColor(Color.BLACK);   
        for (int i = 0; i < 50; i++) {   
            int x = random.nextInt(width);   
            int y = random.nextInt(height);   
            int xl = random.nextInt(5);   
            int yl = random.nextInt(5);  
            gra.setColor(getColor());
            gra.drawLine(x, y, x + xl, y + yl);   
        }   
      
        // 输出数字
        char c;

        for (int i = 0; i < 4; i++) {

            c = s.charAt(i);

            gra.drawString(c + "", i * 25 + 4, 20); // 25为宽度,11为上下高度位置

        }

  OutputStream toClient = response.getOutputStream();
        JPEGImageEncoder encoder = JPEGCodec.createJPEGEncoder(toClient);
        encoder.encode(image);

  toClient.close();

        out.clear();

  out = pageContext.pushBody();
%>
<%!
private Color getColor()
{
 Random random = new Random();
 int red = 0, green = 0, blue = 0;   
 // 产生随机的颜色分量来构造颜色值,这样输出的每位数字的颜色值都将不同。   
     red = random.nextInt(255);   
     green = random.nextInt(255);   
     blue = random.nextInt(255);  
     return new Color(red,green,blue);
}

%>

       3。验证码的验证页面checkcode.jsp

<%@ page language="java" contentType="text/html; charset=GBK"
    pageEncoding="GBK"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=GBK">
<title>验证页面</title>
</head>
<body>
<%
String serverCode = (String)session.getAttribute("validateCode");
String userCode    =new String( request.getParameter("code").getBytes("ISO-8859-1"));
session.removeAttribute("validateCode");
 %>
 <br/>
 <div align="center">
<%=userCode.equals(serverCode)? "输入正确":"输入错误" %>
</div>
</body>
</html>

 

运行结果:

点击登录后会显示你输入的验证码正确与否(区分大小写)

    怎么样,很简单吧?


  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值