0
点赞
收藏
分享

微信扫一扫

JSP生成彩色验证码!


 
 
1. <%@ page contentType="image/jpeg" import="java.awt.*,
2. java.awt.image.*,java.util.*,javax.imageio.*"
3. <%!  
4. Color getRandColor(int fc,int bc){//给定范围获得随机颜色
5. Random random = new
6. if(fc>255) fc=255;  
7. if(bc>255) bc=255;  
8. int
9. int
10. int
11. return new
12. }  
13. %>  
14. <%  
15. //设置页面不缓存
16. response.setHeader("Pragma","No-cache");  
17. response.setHeader("Cache-Control","no-cache");  
18. response.setDateHeader("Expires", 0);  
19.   
20. // 在内存中创建图象
21. int width=60, height=20;  
22. BufferedImage image = new
23.   
24. // 获取图形上下文
25. Graphics g = image.getGraphics();  
26.   
27. //生成随机类
28. Random random = new
29.   
30. // 设定背景色
31. g.setColor(getRandColor(200,250));  
32. g.fillRect(0, 0, width, height);  
33.   
34. //设定字体
35. g.setFont(new Font("Times New Roman",Font.PLAIN,18));  
36.   
37. //画边框
38. //g.setColor(new Color());
39. //g.drawRect(0,0,width-1,height-1);
40.   
41. // 随机产生155条干扰线,使图象中的认证码不易被其它程序探测到
42. g.setColor(getRandColor(160,200));  
43. for (int i=0;i<155;i++)  
44. {  
45. int
46. int
47. int xl = random.nextInt(12);  
48. int yl = random.nextInt(12);  
49. g.drawLine(x,y,x+xl,y+yl);  
50. }  
51.   
52. // 取随机产生的认证码(4位数字)
53. String sRand="";  
54. for (int i=0;i<4;i++){  
55. String rand=String.valueOf(random.nextInt(10));  
56. sRand+=rand;  
57. // 将认证码显示到图象中
58. g.setColor(new Color(20+random.nextInt(110),20+random.nextInt(110),20+random.nextInt(110)));  
59. //调用函数出来的颜色相同,可能是因为种子太接近,所以只能直接生成
60. g.drawString(rand,13*i+6,16);  
61. }  
62.   
63. // 将认证码存入SESSION
64. session.setAttribute("rand",sRand);  
65.   
66. // 图象生效
67. g.dispose();  
68.   
69. // 输出图象到页面
70. ImageIO.write(image, "JPEG", response.getOutputStream());  
71. %>  
72.   
73.   
74. 使用验证码图片的文件a.jsp  
75.   
76. <%@ page contentType="text/html;charset=gb2312"
77. <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">  
78. <html>  
79. <head>  
80. <title>认证码输入页面</title>  
81. <meta http-equiv="Content-Type" content="text/html; charset=gb2312">  
82. <META HTTP-EQUIV="Pragma" CONTENT="no-cache">  
83. <META HTTP-EQUIV="Cache-Control" CONTENT="no-cache">  
84. <META HTTP-EQUIV="Expires" CONTENT="0">  
85. </head>  
86. <body>  
87. <form method=post action="check.jsp">  
88. <table>  
89. <tr>  
90. <td align=left>系统产生的认证码:</td>  
91. <td><img border=0 src="image.jsp"></td>  
92. </tr>  
93. <tr>  
94. <td align=left>输入上面的认证码:</td>  
95. <td><input type=text name=rand maxlength=4 value=""></td>  
96. </tr>  
97. <tr>  
98. <td colspan=2 align=center><input type=submit value="提交检测"></td>  
99. </tr>  
100. </table>  
101. </form>  
102. </body>  
103. </html>  
104.   
105.   
106. 验证的页面check.jsp  
107.   
108. <%@ page contentType="text/html; charset=gb2312" language="java" import="java.sql.*" errorPage=""
109. <html>  
110. <head>  
111. <title>认证码验证页面</title>  
112. <meta http-equiv="Content-Type" content="text/html; charset=gb2312">  
113. <META HTTP-EQUIV="Pragma" CONTENT="no-cache">  
114. <META HTTP-EQUIV="Cache-Control" CONTENT="no-cache">  
115. <META HTTP-EQUIV="Expires" CONTENT="0">  
116. </head>  
117.   
118. <body>  
119. <%  
120. String rand = (String)session.getAttribute("rand");  
121. String input = request.getParameter("rand");  
122. %>  
123. 系统产生的认证码为: <%= rand %><br>  
124. 您输入的认证码为: <%= input %><br>  
125. <br>  
126. <%  
127. if
128. %>  
129. <font color=green>输入相同,认证成功!</font>  
130. <%  
131. } else
132. %>  
133. <font color=red>输入不同,认证失败!</font>  
134. <%  
135. }  
136. %>  
137. </body>  
138. </html>

举报

相关推荐

0 条评论