Jsp常用技巧:图片验证码

2016-02-19 13:22 26 1 收藏

图老师设计创意栏目是一个分享最好最实用的教程的社区,我们拥有最用心的各种教程,今天就给大家分享Jsp常用技巧:图片验证码的教程,热爱PS的朋友们快点看过来吧!

【 tulaoshi.com - Web开发 】

思路:

图片验证码的实现主要的技术点是如何生成一个图片。生成图片可以使用java.awt包下的类来实现。我们先写一个简单的生成图片的程序HelloImage.java。以下是代码部分。

package com.vogoal.test;
import java.awt.Color;
import java.awt.Graphics;
import java.awt.image.BufferedImage;
import java.io.File;
import java.io.IOException;
import javax.imageio.ImageIO;
/**
* @author SinNeR@blueidea.com
* create a image
*/
public class HelloImage {
public static void main(String[] args){
BufferedImage image = new BufferedImage(80, 25,
BufferedImage.TYPE_INT_RGB);
Graphics g = image.getGraphics();
g.setColor(new Color(255,255,255));
g.fillRect(0, 0, 80, 25);
g.setColor(new Color(0,0,0));
g.drawString("HelloImage",6,16);
g.dispose();
try{
ImageIO.write(image, "jpeg", new File("C:helloImage.jpeg"));
}catch(IOException e){
e.printStackTrace();
}
}
}

编译后,在DOS下调用这个程序,正常情况下,会在C盘根目录下生成一张名字helloImage.jpeg为的图片。图片上有文字HelloImage。

简单介绍下生成图片的流程:

(本文来源于图老师网站,更多请访问http://www.tulaoshi.com/webkaifa/)

建立BufferedImage对象。指定图片的长度宽度和色彩。
BufferedImage image = new BufferedImage(80,25,BufferedImage.TYPE_INT_RGB);
取得Graphics对象,用来绘制图片。
Graphics g = image.getGraphics();
绘制图片背景和文字。
释放Graphics对象所占用的资源。
g.dispose();
通过ImageIO对象的write静态方法将图片输出。
ImageIO.write(image, "jpeg", new File("C:helloImage.jpeg"));
知道了图片的生成方法,剩下的问题就是如何将随机数生成到页面上了。要显示图片,我们只要将生成的图片流返回给response对象,这样用户请求的时候就可以得到图片。而一个jsp页面的page参数的contentType属性可以指定返回的response对象的形式,我们平时的jsp页面中设定的contentType是text/html,所以会被以HTML文件的形式读取分析。如果设定为image/jpeg,就会被以图片的形式读取分析。确定了这点后就可以着手实现。

修改生成图片的类,添加生成随机字符串的方法,并取得用户传过来的response对象将图片流输出到response对象中。同时为了更友好和可订制,添加了一个构造函数,可以修改图片验证码的长度,以及验证码的码字范围。并且可以设定验证码的背景色。(用户使用时可以设定验证图片的背景色与页面的背景色相同)
写一个jsp文件,用来调用生成验证码图片的类。并得到生成的验证码,存入session。
以下是生成验证码图片的类RandImgCreater。(操作系统的原因,没有写注释,避免乱码)

package com.vogoal.util.img;
import java.awt.Color;
import java.awt.Font;
import java.awt.Graphics;
import java.awt.image.BufferedImage;
import java.io.IOException;
import java.util.Random;
import javax.imageio.ImageIO;
import javax.servlet.http.HttpServletResponse;
/**
* @author SinNeR
* http://bbs.blueidea.com
* image check creater
*/
public class RandImgCreater {
private static final String CODE_LIST = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz1234567890";
private HttpServletResponse response = null;
private static final int HEIGHT = 20;
private static final int FONT_NUM = 4;
private int width = 0;
private int iNum = 0;
private String codeList = "";
private boolean drawBgFlag = false;

private int rBg = 0;
private int gBg = 0;
private int bBg = 0;
public RandImgCreater(HttpServletResponse response) {
this.response = response;
this.width = 13 * FONT_NUM + 12;
this.iNum = FONT_NUM;
this.codeList = CODE_LIST;
}

public RandImgCreater(HttpServletResponse response,int iNum,String codeList) {
this.response = response;
this.width = 13 * iNum + 12;
this.iNum = iNum;
this.codeList = codeList;
}

public String createRandImage(){
BufferedImage image = new BufferedImage(width, HEIGHT,
BufferedImage.TYPE_INT_RGB);

Graphics g = image.getGraphics();

Random random = new Random();

(本文来源于图老师网站,更多请访问http://www.tulaoshi.com/webkaifa/)

if ( drawBgFlag ){
g.setColor(new Color(rBg,gBg,bBg));
g.fillRect(0, 0, width, HEIGHT);
}else{
g.setColor(getRandColor(200, 250));
g.fillRect(0, 0, width, HEIGHT);

for (int i = 0; i 155; i++) {
g.setColor(getRandColor(140, 200));
int x = random.nextInt(width);
int y = random.nextInt(HEIGHT);
int xl = random.nextInt(12);
int yl = random.nextInt(12);
g.drawLine(x, y, x + xl, y + yl);
}
}

g.setFont(new Font("Times New Roman", Font.PLAIN, 18));

String sRand="";
for (int i=0;iiNum;i++){
int rand=random.nextInt(codeList.length());
String strRand=codeList.substring(rand,rand+1);
sRand+=strRand;
g.setColor(new Color(20+random.nextInt(110),20+random.nextInt(110),20+random.nextInt(110)));
g.drawString(strRand,13*i+6,16);
}
g.dispose();
try{
ImageIO.write(image, "JPEG", response.getOutputStream());
}catch(IOException e){

}

return sRand;
}

public void setBgColor(int r,int g,int b){
drawBgFlag = true;
this.rBg = r;
this.gBg = g;
this.bBg = b;
}
private Color getRandColor(int fc, int bc) {
Random random = new Random();
if (fc 255)
fc = 255;
if (bc 255)
bc = 255;
int r = fc + random.nextInt(bc - fc);
int g = fc + random.nextInt(bc - fc);
int b = fc + random.nextInt(bc - fc);
return new Color(r, g, b);
}
}
以下是调用生成验证码图片的类的jsp文件:

%@ page contentType="image/jpeg" import="com.vogoal.util.img.*" %
%
response.setHeader("Pragma","No-cache");
response.setHeader("Cache-Control","no-cache");
response.setDateHeader("Expires", 0);
RandImgCreater rc = new RandImgCreater(response);
//RandImgCreater rc = new RandImgCreater(response,8,"abcdef");
//rc.setBgColor(100,100,100);
String rand = rc.createRandImage();
session.setAttribute("rand",rand);
%

将java程序编译后得到的class,放到Tomcat自己的web应用的class的目录下,并写一个测试程序。

请求页面:

form name="frm" method="post" action="chkImg.jsp"
Hello Image Testbr/
checkCode:img src="img.jsp"br/
please input the checkCode:input type="text" name="code" value=""br/
input type="submit" name="btn1" value="check"
/form

验证页面:

%
String inputCode = request.getParameter("code");
String code = (String)session.getAttribute("rand");
if ( inputCode.equals(code) ){
%
check SUCCESS!!!!!
%}else{%
wrong code!!!!!!!
%}%

将所有的jsp文件放到自己的web应用的目录下。

开始测试:

启动Tomcat,访问请求页面。

Jsp常用技巧:图片验证码

填入图片上显示的验证码,点击check按钮,可以看到如下画面。测试成功。

Jsp常用技巧:图片验证码

至此,jsp的图片验证码基本实现。实际中,我们可以用java的图片类实现更多的功能。如果有必要,会继续讨论实现方法。

使用帮助:

附件中提供了图片生成类和jsp文件,测试jsp文件的下载。
使用过程中,可以修改img.jsp文件,从而符合自己要实现的功能要求。

1.构造函数
RandImgCreater提供了2个构造函数。
默认的构造函数需要设定response对象。
public RandImgCreater(HttpServletResponse response)
使用这个构造函数的时候,生成4位验证码图片,验证码为大小写英文字母和数字中的随机组合。
public RandImgCreater(HttpServletResponse response,int iNum,String codeList)
使用这个构造函数的时候,iNum为指定的显示的验证码的位数,codeList为用户指定的验证码的生成元字符。(不支持中文)
使用例
RandImgCreater rc = new RandImgCreater(response,8,"abcdef");
将会生成从abcdef中随机取出的8位验证码图片。

2.指定背景色
public void setBgColor(int r,int g,int b)
这个方法可选用。设定的时候,将会按照用户指定的背景色显示图片背景,不设定的时候将使用默认背景。
r,g,b分别为RGB颜色中的各个色彩的设定值。取值范围为0-255
使用例
rc.setBgColor(100,100,100);

来源:http://www.tulaoshi.com/n/20160219/1603969.html

延伸阅读
标签: 生活常识
12306图片验证码如何使用   12306图片验证码如何使用 12306官网为了减少抢票软件的使用,防止黄牛党,推出了图片验证码的方式完成登陆或者下单,有的人一开始对这个图片验证不熟悉,进行图片验证时老是出错,引得不少人吐槽。 如何通过12306图片验证码完成登陆? 进入12306官网之后,来到车票预订页面,再点击顶部...
标签: Web开发
我们在做验证码的时候往往由于要反作弊,验证有时故意加入多的干扰因素,这时验证码显示不很清楚,用户经常输入错误。这样不但要重新刷新页面,导致用户没有看清楚验证码而重填而不是修改,而且如果没有用session保存下用户输入的其它数据的话(如姓名),用户刚刚输入的内容也不存在了,这样给用户造成不好的体验。 本例在原有验证方式基础之上增...
12306验证码怎么用?12306火车票订票网站图片验证码使用教程   12306火车票订票网站的验证码一直是困扰大家的一个大问题,数字+字母的验证码太简单以致于被自动识别验证码的火车票抢票软件滥用,太复杂又让广大乘客很受伤。12306推出了全新的图案验证码,点击所有的某个物品图案实现验证。下面跟小编一起来来看看12306图片验证码怎么...
12306图片验证码怎么取消选择   很简单,再点击一次红色的中国铁路标志,红色标志消失了就表示已经取消选择了。
12306图片验证码怎么样   第一步打开12306的官网,新版售票,点击进入: 第二步:输入自己的账号和密码后,点击"开始验证": 第三步:根据图片提示选择相对应的图片,小编的提示是找出火山的图片,当然这些图片在每次登录的时候都是不一样的,相同的图片可能有2张,也可能有3张,根据实际情况做出相应的选...

经验教程

354

收藏

80
微博分享 QQ分享 QQ空间 手机页面 收藏网站 回到头部