图片验证码实现步骤

一.图片验证码概述:

很多网站都有该实现

作用:

为了提高系统的安全性

有了验证码,我们就可以要求用户在输入用户名,密码等信息后,同时输入图片上的文字,用户提交

后,系统会首先从session中提取刚刚生成的验证码,并和用户输入的验证码进行比较,如果比较

相等,表示用户是从登录界面登录过来的,否则,表示用户是非法的

我们使用验证码,是确保系统的使用必须要进行登录成功之后,才能使用,避免用户直接在地址栏

中输入要访问的页面

也就是说,使用验证码,就强制用户用户必须先从登录界面登录

二:验证实现方式

用到两个关键类,这两个类跟图片的输出是有关系的

BufferedImage im = new BufferedImage(60,20,BufferedImage.TYPE_INT_RGB);

//第一个参数im表示一个图片对象

//JPG表示图片输出类型

//response.getOutputStream()代表一个响应的输出流,也就是说,你访问这个servlet.该

servlet就会图片显示给你

ImageIO.write(im, "JPG",response.getOutputStream());

三.实现步骤

1.使用BufferedImage产生一个图片,然后使用ImageIO输出,并指定为JPG格式

BufferedImage im = new BufferedImage(60,20,BufferedImage.TYPE_INT_RGB);

//第一个参数im表示一个图片对象

//JPG表示图片输出类型

//response.getOutputStream()代表一个响应的输出流,也就是说,你访问这个servlet.该

servlet就会图片显示给你

ImageIO.write(im, "JPG",response.getOutputStream());

2.获取图片绘图对象

Graphics g = im.getGraphics();

3.填充绘图区域

Random rm = new Random();

Color c = new Color(rm.nextInt(255),rm.nextInt(255),rm.nextInt(255));

g.setColor(c);

//填充整个图片的颜色

g.fillRect(0, 0, 60, 20);

4.向图片中输出数字

g.setColor(new Color(rm.nextInt(255),rm.nextInt(255),rm.nextInt(255)));

g.setFont(new Font("华文隶书",Font.BOLD|Font.ITALIC,28));

g.drawString("8", 1, 18);

5.随机4位数字

//随机产生4位数字

for(int i=0;i<4;i++){

g.setColor(new Color(rm.nextInt(255),rm.nextInt(255),rm.nextInt(255)));

g.setFont(new Font("Gungsuh",Font.BOLD|Font.ITALIC,22));

g.drawString(""+rm.nextInt(10), (i*15)+2, 18);

}

6.随机产生中文

String str = "胸有激雷而面如平湖者可拜上将军";

for(int i=0;i<4;i++){

g.setColor(new Color(rm.nextInt(255),rm.nextInt(255),rm.nextInt(255)));

g.setFont(new Font("Gungsuh",Font.BOLD|Font.ITALIC,15));

g.drawString(""+str.charAt(rm.nextInt(str.length())), (i*15)+2, 18);

}

7.在页面中如何来引入该验证码:

验证码

8.保存数字,以便进行登录比较

//将得到的四个数字保存到session中,以便当用户登录的时候,用来比较

request.getSession().setAttribute("piccode", sbf.toString());

9.登录验证

首先,需要验证该用户在数据库中是否存在,如果存在,还需要验证输入的验证码是否一致.

验证成功后,需要转发到相关的操作页面.

代码实例:

boolean b_exist = login.validate(username,passwd);

//如果该用户存在

if(b_exist){

String pic = ""+request.getSession().getAttribute("piccode");

//比较验证码

if(!pic.equals("") && pic.equals(code)){

//向session中存入用户信息,以供其他中来使用

request.getSession().setAttribute("username", username);

response.sendRedirect("index.jsp");

}

}

四.参考资料:

http://blog.163.com/jackie_howe/blog/static/199491347201272410322219/

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 201,681评论 5 474
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 84,710评论 2 377
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 148,623评论 0 334
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,202评论 1 272
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,232评论 5 363
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,368评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,795评论 3 393
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,461评论 0 256
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,647评论 1 295
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,476评论 2 317
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,525评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,226评论 3 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,785评论 3 303
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,857评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,090评论 1 258
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,647评论 2 348
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,215评论 2 341

推荐阅读更多精彩内容

  • http://blog.csdn.net/ayhlay/article/details/13625275 1.验证...
    蘋果_283e阅读 439评论 0 0
  • Spring mvc之java实现登陆时验证码逻辑 摘要 一个优良的web系统的登陆模块或者功能,为了防止机器暴力...
    森森不熄阅读 3,027评论 1 1
  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 171,329评论 25 707
  • 新建JSP文件 如code.jsp 复制如下代码 <%@ page language="java" content...
    矫矫矫阅读 331评论 0 0
  • Java动态代理 引言 最近在看AOP代码,其中利用到了Java动态代理机制来实现AOP织入。所以好好地把Java...
    草捏子阅读 1,515评论 0 18