关于页面表单验证码的实现

一、在Servlet中实现:

 

import java.awt.Color;

import java.awt.Font;

import java.awt.Graphics2D;

import java.awt.image.BufferedImage;

import java.util.Random;

import javax.imageio.ImageIO;

import javax.servlet.*;

import java.io.*;

import javax.servlet.http.*;

import javax.servlet.ServletException;

import javax.servlet.http.HttpServlet;

import javax.servlet.http.HttpServletRequest;

import javax.servlet.http.HttpServletResponse;

public class CreateImage extends HttpServlet {

 

public void doGet(HttpServletRequest request, HttpServletResponse response)

throws ServletException, IOException {

 

this.doPost(request, response);

}

 

public void doPost(HttpServletRequest request, HttpServletResponse response)

throws ServletException, IOException {

 

// 验证码图片的宽度。

int width = 70;

// 验证码图片的高度。

int height = 30;

BufferedImage buffImg = new BufferedImage(width, height,

BufferedImage.TYPE_INT_RGB);

Graphics2D g = buffImg.createGraphics();

 

// 创建一个随机数生成器类。

Random random = new Random();

 

// 设定图像背景色(因为是做背景,所以偏淡)

g.setColor(getRandColor(200, 250));

g.fillRect(0, 0, width, height);

// 创建字体,字体的大小应该根据图片的高度来定。

Font font = new Font("Times New Roman", Font.HANGING_BASELINE, 28);

// 设置字体。

g.setFont(font);

 

// 画边框。

g.setColor(Color.BLACK);

g.drawRect(0, 0, width - 1, height - 1);

// 随机产生155条干扰线,使图象中的认证码不易被其它程序探测到。

// g.setColor(Color.GRAY);

g.setColor(getRandColor(160, 200));

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

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);

}

 

// randomCode用于保存随机产生的验证码,以便用户登录后进行验证。

StringBuffer randomCode = new StringBuffer();

 

// 设置默认生成4个验证码

int length = 4;

// 设置备选验证码:包括"a-z"和数字"0-9"

String base = "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789";

 

int size = base.length();

 

// 随机产生4位数字的验证码。

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

// 得到随机产生的验证码数字。

int start = random.nextInt(size);

String strRand = base.substring(start, start + 1);

 

// 用随机产生的颜色将验证码绘制到图像中。

// 生成随机颜色(因为是做前景,所以偏深)

// g.setColor(getRandColor(1, 100));

 

// 调用函数出来的颜色相同,可能是因为种子太接近,所以只能直接生成

g.setColor(new Color(20 + random.nextInt(110), 20 + random

.nextInt(110), 20 + random.nextInt(110)));

 

g.drawString(strRand, 15 * i + 6, 24);

 

// 将产生的四个随机数组合在一起。

randomCode.append(strRand);

}

// 将四位数字的验证码保存到Session中。

HttpSession session = request.getSession();

if (session.getAttribute("rand") != null) {

session.removeAttribute("rand");

}

session.setAttribute("rand", randomCode.toString());

// 图象生效

g.dispose();

 

// 禁止图像缓存。

response.setHeader("Pragma", "no-cache");

response.setHeader("Cache-Control", "no-cache");

response.setDateHeader("Expires", 0);

 

response.setContentType("image/jpeg");

 

// 将图像输出到Servlet输出流中。

ServletOutputStream sos = response.getOutputStream();

ImageIO.write(buffImg, "jpeg", sos);

sos.flush();

sos.close();

 

}

 

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);

}

 

}

 

二、在struts2的Action中实现:

import java.awt.Color;

import java.awt.Font;

import java.awt.Graphics2D;

import java.awt.image.BufferedImage;

import java.io.ByteArrayInputStream;

import java.io.ByteArrayOutputStream;

import java.util.Random;

 

import javax.imageio.ImageIO;

import javax.imageio.stream.ImageOutputStream;

import javax.servlet.http.HttpSession;

 

import org.apache.struts2.convention.annotation.Namespace;

import org.apache.struts2.convention.annotation.Result;

 

import org.apache.struts2.ServletActionContext;

 

import com.opensymphony.xwork2.ActionSupport;

 

@Namespace("/code")

@Result(name= ActionSupport.SUCCESS, type="stream", params={"contentType", "image/jpeg", 

"inputName", "inputStream"})

public class CodeAction extends ActionSupport {

 

 

private static final long serialVersionUID = 1L;

private ByteArrayInputStream inputStream; 

private String nowTime;

 

@Override

public String execute() throws Exception {

// 验证码图片的宽度。

int width = 70;

// 验证码图片的高度。

int height = 30;

BufferedImage buffImg = new BufferedImage(width, height,

BufferedImage.TYPE_INT_RGB);

Graphics2D g = buffImg.createGraphics();

 

// 创建一个随机数生成器类。

Random random = new Random();

 

// 设定图像背景色(因为是做背景,所以偏淡)

g.setColor(getRandColor(200, 250));

g.fillRect(0, 0, width, height);

// 创建字体,字体的大小应该根据图片的高度来定。

Font font = new Font("Times New Roman", Font.HANGING_BASELINE, 28);

// 设置字体。

g.setFont(font);

 

// 画边框。

g.setColor(Color.BLACK);

g.drawRect(0, 0, width - 1, height - 1);

// 随机产生155条干扰线,使图象中的认证码不易被其它程序探测到。

// g.setColor(Color.GRAY);

g.setColor(getRandColor(160, 200));

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

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);

}

 

// randomCode用于保存随机产生的验证码,以便用户登录后进行验证。

StringBuffer randomCode = new StringBuffer();

 

// 设置默认生成4个验证码

int length = 4;

// 设置备选验证码:包括"a-z"和数字"0-9"

String base = "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789";

 

int size = base.length();

 

// 随机产生4位数字的验证码。

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

// 得到随机产生的验证码数字。

int start = random.nextInt(size);

String strRand = base.substring(start, start + 1);

 

// 用随机产生的颜色将验证码绘制到图像中。

// 生成随机颜色(因为是做前景,所以偏深)

// g.setColor(getRandColor(1, 100));

 

// 调用函数出来的颜色相同,可能是因为种子太接近,所以只能直接生成

g.setColor(new Color(20 + random.nextInt(110), 20 + random

.nextInt(110), 20 + random.nextInt(110)));

 

g.drawString(strRand, 15 * i + 6, 24);

 

// 将产生的四个随机数组合在一起。

randomCode.append(strRand);

}

// 将四位数字的验证码保存到Session中。

HttpSession session = ServletActionContext.getRequest().getSession()

if (session.getAttribute("rand") != null) {

session.removeAttribute("rand");

}

session.setAttribute("rand", randomCode.toString());

// 图象生效

g.dispose();

ByteArrayOutputStream output = new ByteArrayOutputStream();  

   ImageOutputStream imageOut = ImageIO.createImageOutputStream(output);  

ImageIO.write(buffImg, "jpeg", imageOut);

ByteArrayInputStream input = new ByteArrayInputStream(output.toByteArray());  

        this.setInputStream(input);  

        return SUCCESS;

}

public void setInputStream(ByteArrayInputStream inputStream) {  

       this.inputStream = inputStream;  

}  

 

public ByteArrayInputStream getInputStream() {  

       return inputStream;  

}  

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);

}

 

public String getNowTime() {

return nowTime;

}

 

public void setNowTime(String nowTime) {

this.nowTime = nowTime;

}

 

在页面中利用<img/>的src属性引用即可。但是对输入验证的效验只能通过ajax来实现

你可能感兴趣的:(表单验证)