天天看點

JAVA技術:代碼實作驗證碼圖檔的生成

Servlet生成驗證碼圖檔

1 package com.logcd.servlet;  

2   

3 import java.awt.Color;  

4 import java.awt.Font;  

5 import java.awt.Graphics2D;  

6 import java.awt.image.BufferedImage;  

7 import java.util.Random;  

8 import javax.imageio.ImageIO;  

9 import javax.servlet.*; 

10 import java.io.*; 

11 import javax.servlet.http.*; 

12 import javax.servlet.ServletException; 

13 import javax.servlet.http.HttpServlet; 

14 import javax.servlet.http.HttpServletRequest; 

15 import javax.servlet.http.HttpServletResponse; 

16  

17 @SuppressWarnings("serial") 

18 public class RandomCode extends HttpServlet { 

19  

20     public void doGet(HttpServletRequest request, HttpServletResponse response) 

21             throws ServletException, IOException { 

22  

23         this.doPost(request, response); 

24     } 

25  

26     public void doPost(HttpServletRequest request, HttpServletResponse response) 

27             throws ServletException, IOException { 

28  

29         // 驗證碼圖檔的寬度。 

30         int width = 70; 

31         // 驗證碼圖檔的高度。 

32         int height = 30; 

33         BufferedImage buffImg = new BufferedImage(width, height, 34                 BufferedImage.TYPE_INT_RGB); 

35         Graphics2D g = buffImg.createGraphics(); 

36  

37         // 建立一個随機數生成器類。 38         Random random = new Random(); 39  40         // 設定圖像背景色(因為是做背景,是以偏淡) 

41         g.setColor(getRandColor(200, 250)); 

42         g.fillRect(0, 0, width, height); 

43         // 建立字型,字型的大小應該根據圖檔的高度來定。 

44         Font font = new Font("Times New Roman", Font.HANGING_BASELINE, 28); 45         // 設定字型。 

46         g.setFont(font); 47  48         // 畫邊框。 49         g.setColor(Color.BLACK); 50         g.drawRect(0, 0, width - 1, height - 1); 

51         // 随機産生155條幹擾線,使圖象中的認證碼不易被其它程式探測到。 

52 //g.setColor(Color.GRAY); 

53         g.setColor(getRandColor(160,200)); 

54         for (int i = 0; i < 155; i++) { 

55             int x = random.nextInt(width); 

56             int y = random.nextInt(height); 

57             int xl = random.nextInt(12); 

58             int yl = random.nextInt(12); 

59             g.drawLine(x, y, x + xl, y + yl); 

60         } 

61  

62         // randomCode用于儲存随機産生的驗證碼,以便使用者登入後進行驗證。 

63         StringBuffer randomCode = new StringBuffer(); 

64  

65         // 設定預設生成4個驗證碼 

66         int length = 4; 

67         // 設定備選驗證碼:包括"a-z"和數字"0-9" 68         String base = "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789"; 

69  

70         int size = base.length(); 

71  

72         // 随機産生4位數字的驗證碼。 

73         for (int i = 0; i < length; i++) { 74             // 得到随機産生的驗證碼數字。 75             int start = random.nextInt(size); 

76             String strRand = base.substring(start, start + 1); 

77  

78             // 用随機産生的顔色将驗證碼繪制到圖像中。 

79 // 生成随機顔色(因為是做前景,是以偏深) 80 //g.setColor(getRandColor(1, 100)); 81              

82 //調用函數出來的顔色相同,可能是因為種子太接近,是以隻能直接生成 

83             g.setColor(new Color(20+random.nextInt(110),20+random.nextInt(110),20+random.nextInt(110))); 

84  

85             g.drawString(strRand, 15 * i + 6, 24); 

86  

87             // 将産生的四個随機數組合在一起。 

88             randomCode.append(strRand); 

89         } 

90         // 将四位數字的驗證碼儲存到Session中。 

91         HttpSession session = request.getSession(); 

92         session.setAttribute("rand", randomCode.toString()); 

93  

94         //圖象生效 

95         g.dispose(); 

96  

97         // 禁止圖像緩存。 

98         response.setHeader("Pragma", "no-cache"); 

99         response.setHeader("Cache-Control", "no-cache");

100         response.setDateHeader("Expires", 0);

101 

102         response.setContentType("image/jpeg");

103 

104         // 将圖像輸出到Servlet輸出流中。105         ServletOutputStream sos = response.getOutputStream();

106         ImageIO.write(buffImg, "jpeg", sos);

107         sos.flush();

108         sos.close();

109 

110     }

111 

112     Color getRandColor(int fc, int bc) {// 給定範圍獲得随機顔色

113         Random random = new Random();

114         if (fc > 255)

115             fc = 255;

116         if (bc > 255)

117             bc = 255;

118         int r = fc + random.nextInt(bc - fc);

119         int g = fc + random.nextInt(bc - fc);

120         int b = fc + random.nextInt(bc - fc);

121         return new Color(r, g, b);

122     }

123 

124 }

   <b>配置</b>

1     &lt;servlet&gt;

2         &lt;servlet-name&gt;RandomCode&lt;/servlet-name&gt;

3         &lt;servlet-class&gt;com.logcd.servlet.RandomCode&lt;/servlet-class&gt;

4     &lt;/servlet&gt;

5     &lt;servlet-mapping&gt;

6         &lt;servlet-name&gt;RandomCode&lt;/servlet-name&gt;

7         &lt;url-pattern&gt;/randomCode&lt;/url-pattern&gt;

8     &lt;/servlet-mapping&gt;

  <b>調用</b>

1 &lt;meta http-equiv="Content-Type" content="text/html; charset=gb2312" /&gt; 

2 &lt;meta http-equiv="pragma" content="no-cache"/&gt; 

3 &lt;meta http-equiv="cache-control" content="no-cache"/&gt; 

4 &lt;meta http-equiv="expires" content="0"/&gt; 

5  

6 &lt;iframe src="http://127.0.0.1/js_test/randomCode" id="codeFrame" name="codeFrame" frameborder="no" border="0" marginwidth="0" 

7      marginheight="0" scrolling="no" allowtransparency="yes" height="35" width="102"&gt;&lt;/iframe&gt; 

8      &lt;a href="javascript:void(0);" onclick="refreshCode();"&gt;看不清,換一張&lt;/a&gt; 

9     &lt;br&gt; 

10     &lt;span id="codeImg"&gt;&lt;img border=0 src="randomCode"&gt;&lt;/span&gt;

11     &lt;a href="javascript:void(0);" onclick="reloadCode()"&gt;看不清,再換一張&lt;/a&gt;

1 function $(id){ 

2     return document.getElementById(id); 

3 } 

4  

5 /**重新整理iframe**/ 

6 function refreshCode(){ 

7     window.frames["codeFrame"].location.reload(); 

8 } 

10 /**替換圖檔**/

11 function reloadCode(){

12     $("codeImg").innerHTML = "&lt;img border=0 src='randomCode'&gt;";

13 }

本文轉自 wws5201985 51CTO部落格,原文連結:http://blog.51cto.com/wws5201985/735595,如需轉載請自行聯系原作者