下面这段代码可用于Jsp+Servle+JavaBean中做验证码:

  1 <%@ page contentType="image/jpeg" import="java.awt.*,java.awt.image.*,java.util.*,javax.imageio.*" %>
2 <%!
3 Color getRandColor(int fc,int bc){//给定范围获得随机颜色
4 Random random = new Random();
5 if(fc>255) fc=255;
6 if(bc>255) bc=255;
7 int r=fc+random.nextInt(bc-fc);
8 int g=fc+random.nextInt(bc-fc);
9 int b=fc+random.nextInt(bc-fc);
10 return new Color(r,g,b);
11 }
12 %>
13 <%
14 //设置页面不缓存
15 response.setHeader("Pragma","No-cache");
16 response.setHeader("Cache-Control","no-cache");
17 response.setDateHeader("Expires", 0);
18
19 // 在内存中创建图象
20 int width=60, height=20;
21 BufferedImage image = new BufferedImage(width, height, BufferedImage.TYPE_INT_RGB);
22
23 // 获取图形上下文
24 Graphics g = image.getGraphics();
25
26 //生成随机类
27 Random random = new Random();
28
29 // 设定背景色
30 g.setColor(getRandColor(200,250));
31 g.fillRect(0, 0, width, height);
32
33 //设定字体
34 g.setFont(new Font("Times New Roman",Font.PLAIN,18));
35
36 //画边框
37 //g.setColor(new Color());
38 //g.drawRect(0,0,width-1,height-1);
39
40
41 // 随机产生155条干扰线,使图象中的认证码不易被其它程序探测到
42 g.setColor(getRandColor(160,200));
43 for (int i=0;i<155;i++)
44 {
45 int x = random.nextInt(width);
46 int y = random.nextInt(height);
47 int xl = random.nextInt(12);
48 int yl = random.nextInt(12);
49 g.drawLine(x,y,x+xl,y+yl);
50 }
51 // 取随机产生的认证码(4位数字)
52 //String rand = request.getParameter("rand");
53 //rand = rand.substring(0,rand.indexOf("."));
54 String sRand="";
55 for (int i=0;i<4;i++){
56 String rand=String.valueOf(random.nextInt(10));
57 sRand+=rand;
58 // 将认证码显示到图象中
59 g.setColor(new Color(20+random.nextInt(110),20+random.nextInt(110),20+random.nextInt(110)));//调用函数出来的颜色相同,可能是因为种子太接近,所以只能直接生成
60 g.drawString(rand,13*i+6,16);
61 }
62 // 将认证码存入SESSION
63 session.setAttribute("ccode",sRand);
64 // 图象生效
65 g.dispose();
66 // 输出图象到页面
67 ImageIO.write(image, "JPEG", response.getOutputStream());
68 out.clear();
69 out = pageContext.pushBody();
70 %>

下面是通过Struts2做的验证码。其实原理是一样的,只是列在这里好随时看看:

1、login.jsp页面程序

  1 <script type="text/javascript">
2 function changeValidateCode(obj) {
3 //获取当前的时间作为参数,无具体意义
4 var timenow = new Date().getTime();
5 //每次请求需要一个不同的参数,否则可能会返回同样的验证码
6 //这和浏览器的缓存机制有关系,也可以把页面设置为不缓存,这样就不用这个参数了。
7 obj.src="rand.action?d="+timenow;
8 }
9 </script>

在表单中添加下面这句话:

  1 <s:text name="random"></s:text>:
2 <s:textfield name="rand" size="5"></s:textfield>
3 <img src="rand.action" onclick="changeValidateCode(this)" title="点击图片刷新验证码"/>

2:RandomNumUtil.java 生成验证码的类文件

  1 public class RandomNumUtil {
2 private ByteArrayInputStream image;//图像
3 private String str;//验证码
4
5 private RandomNumUtil(){
6 init();//初始化属性
7 }
8 /*
9 * 取得RandomNumUtil实例
10 */
11 public static RandomNumUtil Instance(){
12 return new RandomNumUtil();
13 }
14 /*
15 * 取得验证码图片
16 */
17 public ByteArrayInputStream getImage(){
18 return this.image;
19 }
20 /*
21 * 取得图片的验证码
22 */
23 public String getString(){
24 return this.str;
25 }
26
27 private void init() {
28 // 在内存中创建图象
29 int width=85, height=20;
30 BufferedImage image = new BufferedImage(width, height, BufferedImage.TYPE_INT_RGB);
31 // 获取图形上下文
32 Graphics g = image.getGraphics();
33 // 生成随机类
34 Random random = new Random();
35 // 设定背景色
36 g.setColor(getRandColor(200,250));
37 g.fillRect(0, 0, width, height);
38 // 设定字体
39 g.setFont(new Font("Times New Roman",Font.PLAIN,18));
40 // 随机产生155条干扰线,使图象中的认证码不易被其它程序探测到
41 g.setColor(getRandColor(160,200));
42 for (int i=0;i<155;i++)
43 {
44 int x = random.nextInt(width);
45 int y = random.nextInt(height);
46 int xl = random.nextInt(12);
47 int yl = random.nextInt(12);
48 g.drawLine(x,y,x+xl,y+yl);
49 }
50 // 取随机产生的认证码(6位数字)
51 String sRand="";
52 for (int i=0;i<6;i++){
53 String rand=String.valueOf(random.nextInt(10));
54 sRand+=rand;
55 // 将认证码显示到图象中
56 g.setColor(new Color(20+random.nextInt(110),20+random.nextInt(110),20+random.nextInt(110)));
57 // 调用函数出来的颜色相同,可能是因为种子太接近,所以只能直接生成
58 g.drawString(rand,13*i+6,16);
59 }
60 //赋值验证码
61 this.str=sRand;
62
63 //图象生效
64 g.dispose();
65 ByteArrayInputStream input=null;
66 ByteArrayOutputStream output = new ByteArrayOutputStream();
67 try{
68 ImageOutputStream imageOut = ImageIO.createImageOutputStream(output);
69 ImageIO.write(image, "JPEG", imageOut);
70 imageOut.close();
71 input = new ByteArrayInputStream(output.toByteArray());
72 }catch(Exception e){
73 System.out.println("验证码图片产生出现错误:"+e.toString());
74 }
75
76 this.image=input;/* 赋值图像 */
77 }
78 /*
79 * 给定范围获得随机颜色
80 */
81 private Color getRandColor(int fc,int bc){
82 Random random = new Random();
83 if(fc>255) fc=255;
84 if(bc>255) bc=255;
85 int r=fc+random.nextInt(bc-fc);
86 int g=fc+random.nextInt(bc-fc);
87 int b=fc+random.nextInt(bc-fc);
88 return new Color(r,g,b);
89 }
90 }

3:RandomAction.java  生成验证码的action程序

  1 public class RandomAction extends ActionSupport{
2 private ByteArrayInputStream inputStream;
3 public String execute() throws Exception{
4 RandomNumUtil rdnu=RandomNumUtil.Instance();
5 this.setInputStream(rdnu.getImage());//取得带有随机字符串的图片
6 ActionContext.getContext().getSession().put("random", rdnu.getString());//取得随机字符串放入HttpSession
7 return SUCCESS;
8 }
9 public void setInputStream(ByteArrayInputStream inputStream) {
10 this.inputStream = inputStream;
11 }
12 public ByteArrayInputStream getInputStream() {
13 return inputStream;
14 }
15 }

4:LoginAction.java 验证验证码的action

  1 private String rand; //表单中的rand
2 public String getRand() {
3 return rand;
4 }
5 public void setRand(String rand) {
6 this.rand = rand;
7 }
8 //从session中取出RandomAction.java 中生成的验证码random
9 String arandom=(String)(ActionContext.getContext().getSession().get("random"));
10
11 //下面就是将session中保存验证码字符串与客户输入的验证码字符串对比了
12 if(arandom.equals(this.getRand())) {
13 ActionContext.getContext().getSession().put("user", this.getUsername());
14 return SUCCESS;
15 }
16 else {
17 return ERROR;
18 }

5:配置文件

  1 <!-- Random验证码 -->
2 <action name="rand" class="com.mxl.rand.RandomAction">
3 <result type="stream">
4 <param name="contentType">image/jpeg</param>
5 <param name="inputName">inputStream</param>
6 </result>
7 </action>

注:本文来源于:cnblogs:牛奶、不加糖

Java验证码的更多相关文章

  1. Java 验证码、二维码

    Java 验证码.二维码 资源 需要:   jelly-core-1.7.0.GA.jar网站:   http://lychie.github.io/products.html将下载下来的 jelly ...

  2. springMVC+Java验证码完善注册功能

    这篇文章简单的写了一个java验证码,为之前写过的springMVC注册功能加上验证码,验证码的作用就不多说了,防止机器人程序恶意注册什么的.. 其中User.java,加上了password和cod ...

  3. java制作验证码(java验证码小程序)

    手动制作java的验证码 Web应用验证码的组成: (1)输入框 (2)显示验证码的图片 验证码的制作流程: 生成验证码的容器使用 j2ee的servlet 生成图片需要的类: (1) Buffere ...

  4. Java 验证码识别库 Tess4j 学习

    Java 验证码识别库 Tess4j 学习 [在用java的Jsoup做爬虫爬取数据时遇到了验证码识别的问题(基于maven),找了网上挺多的资料,发现Tess4j可以自动识别验证码,在这里简单记录下 ...

  5. Java 验证码工具类

    package com.wuyu.util; import java.awt.Color; import java.awt.Font; import java.awt.Graphics; import ...

  6. java 验证码

    package lizikj.bigwheel.pcsystem.util;import javax.imageio.ImageIO; import java.awt.*; import java.a ...

  7. java验证码组件kaptcha使用方法

    使用方法: 项目中导入kaptcha-2.3.jar包在web.xml里面新增: <!-- 登陆验证码Kaptcha -->    <servlet>        <s ...

  8. java验证码-汉字验证码

    今天整理了一个java实现的汉字输入验证码 主要包含两个类,一个是生成验证码,一个是判断验证码输入是否正确 实现原理非常简单,将汉字和干扰线生成图片并将汉字保存到session,前台获取每次生成验证码 ...

  9. 漂亮的自制java验证码

    网上有很多开源的验证码插件,例如jcaptcha,kaptcha等等...这些都不错,不过感觉用起来不太舒服,最后还是网上找了个原型的,然后在这个基础上修改下,效果还算不错,凑合用下,验证码要做到难以 ...

  10. java验证码(采用struts2实现)转

    第一步:编写验证码的Action package com; import java.awt.Color; import java.awt.Font; import java.awt.Graphics; ...

随机推荐

  1. DOM表格操作

    注意:就算代码中不包含<tbody>标签,浏览器解析时也可能会自动添加,因此需要注意子元素的选择 表格操作用到的属性: 1.tHead 2.tBodies 3.tFoot 更为细致的有: ...

  2. python备份网站,并删除指定日期文件

    #!/usr/bin/python# Filename: backup_ver1.pyimport osimport timeimport datetime# 1. The files and dir ...

  3. list 删除一个元素的三种做法--python

    我们以一个字符串为元素类型的 list 为例,进行列表元素的删除: l = ['no surfing', 'flippers'] 法一:remove(val) >>> l.remov ...

  4. the difference __str__ and __repr__

    First, let me reiterate the main points in Alex’s post: The default implementation is useless (it’s ...

  5. Nvivo

    sklearn实战-乳腺癌细胞数据挖掘(博客主亲自录制视频教程) https://study.163.com/course/introduction.htm?courseId=1005269003&a ...

  6. 通过Cloudera Manager部署CDH5.15.1的webUI界面详解

    通过Cloudera Manager部署CDH5.15.1的webUI界面详解 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 本篇博客CDH的部署完全通过Cloudera Mana ...

  7. OSPF基础介绍

    OSPF基础介绍 一.RIP的缺陷 1.以跳数评估的路由并非最优路径 2.最大跳数16导致网络尺度小 3.收敛速度慢 4.更新发送全部路由表浪费网络资源 二.OSPF基本原理 1.什么是OSPF a& ...

  8. javascript 利用冒泡机制显示与隐藏模态框

    <!DOCTYPE html> <html> <head lang="en"> <meta charset="UTF-8&quo ...

  9. ZOJ 4019 Schrödinger's Knapsack

    Schrödinger's Knapsack Time Limit: 1 Second      Memory Limit: 65536 KB DreamGrid has a magical knap ...

  10. C++ 输入输出八进制、十进制、十六进制

    默认进制 cin or cout在默认情况下按照十进制输入输出 八进制 要使输入为八进制数,首先切换至八进制输入 cin >> oct; //接下里就可以输入八进制数了 cin >& ...