package com.hanfeng.test;
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.ServletException;
import javax.servlet.ServletOutputStream;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;
public class ImageServlet extends HttpServlet {
// 验证码图片的宽度。
private int width=60;
//验证码图片的高度。
private int height=20;
protected void service(HttpServletRequest req, HttpServletResponse resp)
throws ServletException, java.io.IOException
{
BufferedImage buffimg=new BufferedImage(width,height,
BufferedImage.TYPE_INT_RGB);
Graphics2D g=buffimg.createGraphics();
//创建一个随机数生成器类。
Random random=new Random();
g.setColor(Color.white);
g.fillRect(0,0,width,height);
//创建字体,字体的大小应该根据图片的高度来定。
Font font=new Font("times new roman",Font.PLAIN,18);
//设置字体。
g.setFont(font);
//画边框。
g.setColor(Color.black);
g.drawRect(0,0,width-1,height-1);
//随机产生160条干扰线,使图象中的认证码不易被其它程序探测到。
g.setColor(Color.gray);
for (int i=0;i<10;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();
int red=0,green=0,blue=0;
//随机产生4位数字的验证码。
for (int i=0;i<4;i++)
{
//得到随机产生的验证码数字。
String strrand=String.valueOf(random.nextInt(10));
//产生随机的颜色分量来构造颜色值,这样输出的每位数字的颜色值都将不同。
red=random.nextInt(200);
green=random.nextInt(200);
blue=random.nextInt(200);
//产生随机高度 13至height之间
float imght = 0;
while(imght<=12){
imght = Float.parseFloat(String.valueOf(random.nextInt(height)));
}
//用随机产生的颜色将验证码绘制到图像中。
g.setColor(new Color(red,green,blue));
g.drawString(strrand,13*i+6,imght);
//将产生的四个随机数组合在一起。
randomcode.append(strrand);
}
//将四位数字的验证码保存到session中。
HttpSession session=req.getSession();
session.setAttribute("VerifyCode",randomcode.toString());
//禁止图像缓存。
resp.setHeader("pragma","no-cache");
resp.setHeader("cache-control","no-cache");
resp.setDateHeader("expires", 0);
resp.setContentType("image/jpeg");
//将图像输出到servlet输出流中。
ServletOutputStream sos=resp.getOutputStream();
ImageIO.write(buffimg, "jpeg",sos);
sos.close();
}
}
分享到:
相关推荐
jsp验证码实现源代码,用jsp做注册验证码
JSP验证码实现源代码,主要采用4为随机生成的数字然后制成相应的图片进行验证,并有验证后的结果显示
jsp验证码实现源码,用于用户输入页面防止重复提交的验证码功能。代码完整欢迎大家下载。
已经测试过的简易验证码实现方式。 简单易懂,可直接使用。
用JSP实现验证码功能 Image.jsp为要被调用的验证码,LOGIN.JSP是登陆调用的例子 解决getOutStream()引发的问题
JSP数字验证码 JSP数字验证码 JSP数字验证码 JSP数字验证码 JSP数字验证码
过分过分过分个自从用ASP来编写网站,就无时无刻想找一种兼容性强,使用方便的上传方法,用过很多的无 组件上传方法,但是都存在使用不方便,兼容性差,速度慢等的问题。终于在2003年的元旦里,想 ...
JSP彩色验证码的实现JSP彩色验证码的实现JSP彩色验证码的实现JSP彩色验证码的实现
JSP实现的图片验证码, 验证码JSP实现 .
经典JSP生成验证码经典JSP生成验证码经典JSP生成验证码经典JSP生成验证码经典JSP生成验证码经典JSP生成验证码经典JSP生成验证码
jsp页面验证码实现jsp页面验证码实现jsp页面验证码实现
jsp servlet实现验证码功能 绝对可用!
jsp验证码生成,提交拦截,jsp验证码生成,提交拦截,jsp验证码生成,提交拦截,jsp验证码生成,提交拦截,
JSP 中文验证码 实现方法 JSP 中文验证码 实现方法
JSP验证码+自动刷新功能,文件的image.jsp是负责生成验证码的,而display.jsp是负责显示效果.简单易用,平时会出现的异常都已经全部解决.
Jsp 登录 验证码 实现
基于JSP的彩色验证码实现。需要注意的地方是验证码是为了安全才加的,所以把它做成图片的格式让别人难以破解。所以contentType="image/jpeg; charset=utf-8"而不是 contentType="text/html; charset=utf-8
jsp实现图形验证码