<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    posts - 66,comments - 41,trackbacks - 0
     生成有4個隨機數字和雜亂背景的圖片,數字和背景顏色會改變,服務器端刷新(用history.go(-1)也會變)
        原型參考ALIBABA  http://china.alibaba.com/member/showimage
        產生驗證碼圖片的文件-----image.jsp

        <%@ 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);

        // 在內存中創(chuàng)建圖象
        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());


        %>

        ---------------使用驗證碼圖片的文件---------a.jsp------------------------------------

        <%@ page contentType="text/html;charset=gb2312" %>
        <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
        <html>
        <head>
        <title>認證碼輸入頁面</title>
        <meta http-equiv="Content-Type" content="text/html; charset=gb2312">
        <META HTTP-EQUIV="Pragma" CONTENT="no-cache">
        <META HTTP-EQUIV="Cache-Control" CONTENT="no-cache">
        <META HTTP-EQUIV="Expires" CONTENT="0">
        </head>
        <body>
        <form method=post action="check.jsp">
        <table>
        <tr>
        <td align=left>系統產生的認證碼:</td>
        <td><img border=0 src="image.jsp"></td>
        </tr>
        <tr>
        <td align=left>輸入上面的認證碼:</td>
        <td><input type=text name=rand maxlength=4 value=""></td>
        </tr>
        <tr>
        <td colspan=2 align=center><input type=submit value="提交檢測"></td>
        </tr>
        </form>
        </body>
        </html>

        -----------------驗證的頁面----------check.jsp

        <%@ page contentType="text/html; charset=gb2312" language="java" import="java.sql.*" errorPage="" %>
        <html>
        <head>
        <title>認證碼驗證頁面</title>
        <meta http-equiv="Content-Type" content="text/html; charset=gb2312">
        <META HTTP-EQUIV="Pragma" CONTENT="no-cache">
        <META HTTP-EQUIV="Cache-Control" CONTENT="no-cache">
        <META HTTP-EQUIV="Expires" CONTENT="0">
        </head>

        <body>
        <%
         String rand = (String)session.getAttribute("rand");
         String input = request.getParameter("rand");
        %>
        系統產生的認證碼為: <%= rand %><br>
        您輸入的認證碼為: <%= input %><br>
        <br>
        <%
          if (rand.equals(input)) {
        %>
        <font color=green>輸入相同,認證成功!</font>
        <%
          } else {
        %>
        <font color=red>輸入不同,認證失敗!</font>
        <%
          }
        %>
        </body>
        </html>



    MSN:
    posted on 2008-04-24 23:50 kylixlu 閱讀(187) 評論(0)  編輯  收藏 所屬分類: JSP

    只有注冊用戶登錄后才能發(fā)表評論。


    網站導航:
     
    主站蜘蛛池模板: 日韩高清在线高清免费| 人妻仑刮八A级毛片免费看| 四虎影视在线影院在线观看免费视频| 亚洲Av无码乱码在线znlu| 亚洲av综合日韩| 国产精品冒白浆免费视频| 亚洲成aⅴ人片久青草影院按摩 | 18观看免费永久视频| 西西人体44rt高清亚洲| 国产精品免费福利久久| 亚洲综合精品一二三区在线| 最近高清中文字幕免费| 亚洲美女一区二区三区| 国产美女做a免费视频软件| 亚洲国产欧美国产综合一区 | 国产gv天堂亚洲国产gv刚刚碰| sss在线观看免费高清| 亚洲精品无码MV在线观看| 久热免费在线视频| 亚洲欧洲在线播放| 性色av无码免费一区二区三区| 久久亚洲精品无码av| 奇米影视亚洲春色| 99国产精品免费视频观看| 亚洲三级在线观看| 免费一级毛片女人图片| 国产成年无码久久久免费| 亚洲第一精品电影网| 成人免费网站在线观看| 一级毛片免费一级直接观看| 亚洲AV日韩AV天堂一区二区三区| 久久久久久免费视频| 污网站在线免费观看| 亚洲AV无码日韩AV无码导航| 亚洲人成网站18禁止| 亚洲区小说区图片区| 182tv免费视视频线路一二三| 亚洲丁香婷婷综合久久| 亚洲人成人77777网站| 国产成人A在线观看视频免费| 一级免费黄色大片|