Java验证码
下面这段代码可用于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>
Java验证码的更多相关文章
- Java 验证码、二维码
Java 验证码.二维码 资源 需要: jelly-core-1.7.0.GA.jar网站: http://lychie.github.io/products.html将下载下来的 jelly ...
- springMVC+Java验证码完善注册功能
这篇文章简单的写了一个java验证码,为之前写过的springMVC注册功能加上验证码,验证码的作用就不多说了,防止机器人程序恶意注册什么的.. 其中User.java,加上了password和cod ...
- java制作验证码(java验证码小程序)
手动制作java的验证码 Web应用验证码的组成: (1)输入框 (2)显示验证码的图片 验证码的制作流程: 生成验证码的容器使用 j2ee的servlet 生成图片需要的类: (1) Buffere ...
- Java 验证码识别库 Tess4j 学习
Java 验证码识别库 Tess4j 学习 [在用java的Jsoup做爬虫爬取数据时遇到了验证码识别的问题(基于maven),找了网上挺多的资料,发现Tess4j可以自动识别验证码,在这里简单记录下 ...
- Java 验证码工具类
package com.wuyu.util; import java.awt.Color; import java.awt.Font; import java.awt.Graphics; import ...
- java 验证码
package lizikj.bigwheel.pcsystem.util;import javax.imageio.ImageIO; import java.awt.*; import java.a ...
- java验证码组件kaptcha使用方法
使用方法: 项目中导入kaptcha-2.3.jar包在web.xml里面新增: <!-- 登陆验证码Kaptcha --> <servlet> <s ...
- java验证码-汉字验证码
今天整理了一个java实现的汉字输入验证码 主要包含两个类,一个是生成验证码,一个是判断验证码输入是否正确 实现原理非常简单,将汉字和干扰线生成图片并将汉字保存到session,前台获取每次生成验证码 ...
- 漂亮的自制java验证码
网上有很多开源的验证码插件,例如jcaptcha,kaptcha等等...这些都不错,不过感觉用起来不太舒服,最后还是网上找了个原型的,然后在这个基础上修改下,效果还算不错,凑合用下,验证码要做到难以 ...
- java验证码(采用struts2实现)转
第一步:编写验证码的Action package com; import java.awt.Color; import java.awt.Font; import java.awt.Graphics; ...
随机推荐
- 四个修改Docker默认存储位置的方法
方法一.软链接 默认情况下Docker的存放位置为:/var/lib/docker 可以通过下面命令查看具体位置: sudo docker info | grep "Docker Root ...
- WCF开发实战系列四:使用Windows服务发布WCF服务
WCF开发实战系列四:使用Windows服务发布WCF服务 (原创:灰灰虫的家http://hi.baidu.com/grayworm) 上一篇文章中我们通过编写的控制台程序或WinForm程序来为本 ...
- java.lang.ClassCastException:java.util.LinkedHashMap不能转换为com.testing.models.Account
ObjectMapper mapper=new ObjectMapper();POJO pojo = mapper.convertValue(singleObject, POJO.class);
- 函数和常用模块【day04】:函数参数及调用(二)
本节内容 1.为什么要有参数 2.返回值 3.有参数函数调用 一.为什么要有参数? 无参数实现 def CPU报警邮件() #发送邮件提醒 连接邮箱服务器 发送邮件 关闭连接 def 硬盘报警邮件() ...
- JS 求一组数中所有数的和以及平均值
var arr = [10,20,30]; //计数器思想 var sum = 0; for(var i=0;i<arr.length;i++){ sum += arr[i]; } consol ...
- for、foreach和Iterator区别及ConcurrentModificationException异常
(问:1.for.foreach和Iterator遍历有什么区别 2.遍历删除ConcurrentModificationException异常.) 1.在形式上 for的形式是 for(int ...
- python番外篇--sql注入
一.sql注入概念介绍 所谓SQL注入,就是通过把SQL命令插入到Web表单提交或输入域名或页面请求的查询字符串,最终达到欺骗服务器执行恶意的SQL命令.具体来说,它是利用现有应用程序,将(恶意的)S ...
- Linux 开机启动图形界面,shell界面
查看当前启动模式 # systemctl get-default 更改模式命令: systemctl set-default graphical.target由命令行模式更改为图形界面模式 syste ...
- android 加载图片
package mydemo.mycom.demo2; import android.graphics.Bitmap; import android.graphics.BitmapFactory; i ...
- Java HotSpot(TM) 64-Bit Server VM warning: ignoring option MaxPermSize=128m; support was removed in 8.0
1 启动hbase的时候爆出警告 Java HotSpot(TM) 64-Bit Server VM warning: ignoring option MaxPermSize=128m; suppor ...