首页

分享基于jsp页面实现的数字图形验证码示例代码说明及效果展示

标签:图形验证码,jsp,java,源码,原理     发布时间:2017-06-20   

一、分享说明

这边基于Java的java.awt.image.*,javax.imageio.*包提供的图形化渲染类实现,并通过将生产后的验证码sRand保存在session页面对象中,从而将用户提交验证码和会话中的对应验证码匹配,效果如下图所示

分享基于jsp页面实现的数字图形验证码示例代码说明及效果展示

二、代码示例

<%@ page contentType="image/jpeg" import="java.util.*,java.awt.*,java.io.*,java.awt.image.*,javax.imageio.*" pageEncoding="utf-8"%>@b@@b@<%!@b@@b@Color getRandColor(int fc,int bc){//给定范围获得随机颜色@b@@b@Random random = new Random();@b@@b@if(fc>255) fc=255;@b@@b@if(bc>255) bc=255;@b@@b@int r=fc+random.nextInt(bc-fc);@b@@b@int g=fc+random.nextInt(bc-fc);@b@@b@int b=fc+random.nextInt(bc-fc);@b@@b@return new Color(r,g,b);@b@@b@}@b@@b@%>@b@@b@<%@b@@b@//设置页面不缓存@b@@b@response.setHeader("Pragma","No-cache");@b@@b@response.setHeader("Cache-Control","no-cache");@b@@b@response.setDateHeader("Expires", 0);@b@@b@// 在内存中创建图象@b@@b@int width=60, height=20;@b@@b@BufferedImage image = new BufferedImage(width, height, BufferedImage.TYPE_INT_RGB);@b@@b@// 获取图形上下文@b@@b@Graphics g = image.getGraphics();@b@@b@//生成随机类@b@@b@Random random = new Random();@b@@b@// 设定背景色@b@@b@g.setColor(getRandColor(200,250));@b@@b@g.fillRect(0, 0, width, height);@b@@b@//设定字体@b@@b@g.setFont(new Font("Times New Roman",Font.PLAIN,18));@b@@b@//画边框@b@@b@//g.setColor(new Color());@b@@b@//g.drawRect(0,0,width-1,height-1);@b@@b@// 随机产生155条干扰线,使图象中的认证码不易被其它程序探测到@b@@b@g.setColor(getRandColor(160,200));@b@@b@for (int i=0;i<155;i++)@b@@b@{@b@@b@int x = random.nextInt(width);@b@@b@int y = random.nextInt(height);@b@@b@int xl = random.nextInt(12);@b@@b@int yl = random.nextInt(12);@b@@b@g.drawLine(x,y,x+xl,y+yl);@b@@b@}@b@@b@// 取随机产生的认证码(4位数字)@b@@b@String sRand="";@b@@b@for (int i=0;i<4;i++){@b@@b@String rand=String.valueOf(random.nextInt(10));@b@@b@sRand+=rand;@b@@b@// 将认证码显示到图象中@b@@b@g.setColor(new Color(20+random.nextInt(110),20+random.nextInt(110),20+random.nextInt(110)));// 调用函数出来的颜色相同,可能是因为种子太接近,所以只能直接生成@b@@b@g.drawString(rand,13*i+6,16);@b@@b@}@b@@b@// 将认证码存入SESSION@b@@b@session.setAttribute("rand",sRand);@b@@b@// 图象生效@b@@b@g.dispose();@b@@b@OutputStream output=response.getOutputStream();@b@@b@// 输出图象到页面@b@@b@ImageIO.write(image, "JPEG", response.getOutputStream());@b@@b@output.flush();@b@@b@out.clear();@b@@b@out = pageContext.pushBody();@b@@b@%>