验证码实现(随机背景色及字体颜色,带扰乱线条)

此实现工分三个文件,即:CreatImage.java 生成图像流的类,提供用于生成图片流的方法;images.jsp 图片包装,用于将图片加入到response输出流中;login.jsp 调用前面的jsp,显示验证码。

下面是源代码:

 1 package com;
 2 
 3 import java.awt.Color;
 4 import java.awt.Font;
 5 import java.awt.Graphics;
 6 import java.awt.Image;
 7 import java.awt.image.BufferedImage;
 8 import java.util.Random;
 9 
10 import javax.servlet.http.HttpServletRequest;
11 import javax.servlet.http.HttpServletResponse;
12 import javax.servlet.http.HttpSession;
13 
14 public class CreatImage{
15    
16     private static final long serialVersionUID = 1L;
17     Image image = null;
18     HttpServletRequest request = null;
19     HttpServletResponse response = null;
20     
21     public CreatImage(HttpServletRequest request, HttpServletResponse response){
22         this.request = request;
23         this.response = response;
24     }
25     
26     public Color getRandColor(int fc,int bc){//给定范围获得随机颜色
27         Random random = new Random();
28         if(fc>255) fc=255;
29         if(bc>255) bc=255;
30         int r=fc+random.nextInt(bc-fc);
31         int g=fc+random.nextInt(bc-fc);
32         int b=fc+random.nextInt(bc-fc);
33         return new Color(r,g,b);
34     }
35     
36     public BufferedImage creatImage(){
37          int width=100, height=26;
38          //生成随机类
39          Random random = new Random();
40          BufferedImage image = new BufferedImage(width, height, BufferedImage.TYPE_INT_RGB);
41          //获取图形上下文
42          Graphics g = image.getGraphics();
43          // 设定背景色
44          g.setColor(getRandColor(200,250));
45          g.fillRect(0, 0, width, height);
46          //设定字体
47          g.setFont(new Font("Times New Roman",Font.PLAIN,22));
48     
49          //画边框
50          //g.setColor(getRandColor(200,250));
51          //g.drawRect(0,0,width,height);
52     
53          // 随机产生155条干扰线,使图象中的认证码不易被其它程序探测到
54          g.setColor(getRandColor(160,200));
55          for (int i=0;i<155;i++){
56            int x = random.nextInt(width);
57            int y = random.nextInt(height);
58            int xl = random.nextInt(12);
59            int yl = random.nextInt(12);
60            g.drawLine(x,y,x+xl,y+yl);
61          }
62          // 取随机产生的认证码(4位数字)
63          //String rand = request.getParameter("rand");
64          //rand = rand.substring(0,rand.indexOf("."));  
65          String str1=randomStr(4);// 得到随机字符
66          HttpSession session = request.getSession();
67          session.setAttribute("validatenumber",str1);
68          //System.out.println(str1);
69          for (int i=0;i<4;i++){
70              String rand=str1.substring(i,i+1);
71              // 将认证码显示到图象中
72              g.setColor(new Color(20+random.nextInt(110),20+random.nextInt(110),20+random.nextInt(110)));
73              //调用函数出来的颜色相同,可能是因为种子太接近,所以只能直接生成
74              g.drawString(rand,20*i+12,20);
75          }
76          // 图象生效
77          g.dispose();
78          return image;
79     }
80    
81   // 得到随机字符
82   public  String randomStr(int n) {
83       String str1 = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz1234567890";
84       String str2 = "";
85       int len = str1.length() - 1;
86       double r;
87       for (int i = 0; i < n; i++) {
88           r = (Math.random()) * len;
89           str2 = str2 + str1.charAt((int) r);
90       }
91       return str2;
92   }
93 }
 1 <%@ page language="java" contentType="image/jpeg ; charset=UTF-8"
 2     pageEncoding="UTF-8" import="java.awt.*,java.awt.image.*,javax.imageio.*,java.io.*"%>
 3 <%@ page import ="com.CreatImage"%>
 4 <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
 5 <html>
 6 <head>
 7 <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
 8 <title>Insert title here</title>
 9 </head>
10 <body>
11 <%
12     response.setHeader("Pragma","No-cache");
13     response.setHeader("Cache-Control","no-cache");
14     response.setDateHeader("Expires", 0);
15 
16     CreatImage c = new CreatImage(request,response);
17     BufferedImage  image = c.creatImage();
18     OutputStream b = response.getOutputStream();
19 %>
20 <%
21     ImageIO.write(image, "JPEG", response.getOutputStream());
22     //必须添加以下两行否则tomcat下jsp出现getOutputStream() has already been called for this response异常
23     out.clear();
24     out = pageContext.pushBody();
25 %>
26 </body>
27 </html>

注意   contentType="image/jpeg ; charset=UTF-8"

 1 <%@ page language="java" contentType="text/html; charset=UTF-8"
 2     pageEncoding="UTF-8"%>
 3 <%
 4     String path = request.getContextPath();
 5 %>
 6 <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
 7 <html>
 8 <head>
 9 <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
10 <title>Insert title here</title>
11 <script>
12      function changeCode()
13      {
14             document.getElementById("cc").src="<%=path%>/images.jsp?a="+Math.random();
15      }
16 </script>
17 </head>
18 <body>
19 <form action="" method="post">    
20 <table cellspacing="2px" cellpadding="2px" align="center">
21 <tr>
22     <td>用户名:</td>
23     <td><input type="text" id="name" value=""/></td>
24 </tr>
25 <tr>
26     <td>密&nbsp;&nbsp;码:</td>
27     <td><input type="password" id="password" value=""/></td>
28 </tr>
29 <tr height="26px">
30     <td>验证码:</td><td valign="middle"><input type="text" id="validate"></td>
31     <td><a href="#" onclick="changeCode();"><img alt="" border="0" id="cc" src="<%=path %>/images.jsp"/></a></td>
32 </tr>
33 <tr>
34     <td colspan="2" align="center"><input type="button" name="button" value="submit"/></td>
35 </tr>
36 </table>
37 </form>
38 </body>
39 </html>
40 
41 

应各位的请求,我把效果图和源文件都放了上来,这样的实现方式我也是参考了别人的博客,不妥之处,还请各位指摘。

validation demo

posted on 2009-12-08 15:44 macoo 阅读(...) 评论(...) 编辑 收藏

转载于:https://www.cnblogs.com/macooma/archive/2009/12/08/1619483.html

验证码实现(随机背景色及字体颜色,带扰乱线条)相关推荐

  1. Eclipse详细设置护眼背景色和字体颜色并导出

    Eclipse详细设置护眼背景色和字体颜色并导出 Eclipse是一款码农们喜闻乐见的集成开发平台,但是其默认的主题和惨白的背景色实在是太刺激眼球了.下面,将给大家详细介绍如何设置成护眼主题的方法,也 ...

  2. 修改导航栏的背景色和字体颜色

    项目基本接近尾声,闲来无事,把项目中用的的一些平时不常用的小技巧总结一下.以前每次使用都是现用现查,想着反正也都能查出来,就没有做记录.因为很多也都记不住,用完时间长不用的话就又忘了.现在有时间,自己 ...

  3. KEIL5护眼背景色以及字体颜色

    将文件替换为UV4安装目录下的  global.prop.def  即可. KEIL5护眼背景色以及字体颜色-C文档类资源-CSDN下载1更多下载资源.学习资料请访问CSDN下载频道.https:// ...

  4. Eclipse设置护眼背景色以及字体颜色

    Eclipse设置护眼背景色和字体颜色 Eclipse是一款码农们喜闻见乐的集成开发工具,但是其默认的主题和惨白的背景色实在是太刺激眼球了.下面,讲给大家详细介绍如何设置成护眼主题的方法,也希望之后会 ...

  5. Eclipse详细设置护眼背景色和字体颜色并导出(转自百度)

    Eclipse是一款码农们喜闻乐见的集成开发平台,但是其默认的主题和惨白的背景色实在是太刺激眼球了.下面,将给大家详细介绍如何设置成护眼主题的方法,也做个抛砖引玉,希望能有更多的主题出现在Eclips ...

  6. c语言vc怎么改变背景板颜色,vc6.0中更改对话框背景色和字体颜色

    方法一:设置所有窗口的颜色     MFC程序修改对话框的背景和文字颜色最简单的方法就是调用SetDialogBkColor函数,SetDialogBkColor是CWinApp类的成员函数,以下是该 ...

  7. android沉浸式 字体,Android沉浸式状态栏背景色以及字体颜色的修改

    在activity中设置透明状态栏 的思路: 1.让activity的布局全屏 此时布局会和状态栏重叠 2.让布局最上方预留出和状态栏高度一样的高度,将状态栏的背景色设置为透明 效果如下: 一般是在s ...

  8. 代码示例001:Grid背景色与字体颜色

    Grid背景色设置 'Background-Color:' + if(types='0', 'white', if(types='1', 'red', if(types='2', 'yellow', ...

  9. 安卓修改顶部状态栏背景色和字体颜色

    在AndroidManifest文件: <application...android:theme="@style/xxxx"> 点进theme: <style n ...

最新文章

  1. JDBC数据源连接池(1)---DBCP
  2. C语言/C++ 中除法得到结果的精度问题(有浮点数参与除法,结果就是浮点数,除数和被除数都是整数,结果默认是整数)
  3. presentViewController和pushViewController
  4. mysql一个事务多个log_MySQL的两阶段事务提交是否先写binlog再写redolog也可行?
  5. 计算机系统的主要功能要求,计算机系统的主要功能是什么
  6. 【设计模式】适配器模式(Adapter Pattern)
  7. spring 事物的级别_Spring 事务中的隔离级别有哪几种?
  8. java repl_Java REPL – jshell
  9. winform中的小技巧【自用】
  10. PSTN ,PBX ,IP PBX,VoIP
  11. LINUX安装7Zip
  12. Hero引擎47个各种问题解答
  13. Android App拥有system权限
  14. 2021-02-24 PMP 群内练习题 - 光环
  15. graphormer 代码阅读
  16. 2019年第三方支付牌照名单(全系列)
  17. 工作面试总遇秒杀? 看了京东 T8 大咖私藏的秒杀系统笔记, 已献出膝盖
  18. python3如何随机生成大数据存储到指定excel文档里
  19. 物联网RFID技术在高速ETC中的应用
  20. Python3.8.5安装教程

热门文章

  1. 三目运算符引发的一次事故
  2. 网站禁止复制怎样操作
  3. 2005年4月全国计算机等级考试二级C语言笔试试题及答案
  4. LNMP和LAMP的编译安装
  5. OFBiz + Opentaps 仓储设施 基本管理
  6. ACTIVEX DLL时,如何在回调函数中改变DLL的一些私有变量的值,并触发用户事件?...
  7. 【Vista中系统准备工具存在隐患,自动清除用户资料】
  8. Elasticsearch 安装和使用
  9. 转:设置session过期时间
  10. Android视图重绘,使用invalidate还是requestLayout