struts2 实现图片验证码(完整代码)

本文通过详细步骤展示了如何在Struts2框架中实现图片验证码功能:创建验证码生成action,配置返回文件流的action,设计测试HTML页面,以及客户端验证代码。点击图片可动态更换验证码。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在struts2下实现了图片验证码的实例,基本思想如下:

1.实现产生图片验证码的action

2.配置action,将上述action返回的逻辑结果设置为文件流类型

3.写一个测试的html页面,使其请求上面的action,得到返回的图片结果。

4.运行结果,点击图片可以改变验证码。

 

1.实现产生图片验证码的action

public class VerifyCode extends ActionSupport {
 private ByteArrayInputStream inputStream;   
    public String execute() throws Exception{   
        RandomNumUtil rdnu=RandomNumUtil.Instance();   
        this.setInputStream(rdnu.getImage());//取得带有随机字符串的图片   
        ActionContext.getContext().getSession().put("random", rdnu.getString());//取得随机字符串放入HttpSession
        return SUCCESS;   
    }   
    public void setInputStream(ByteArrayInputStream inputStream) {   
        this.inputStream = inputStream;   
    }   
    public ByteArrayInputStream getInputStream() {   
        return inputStream;   
    }  
}

 
public class RandomNumUtil {
 private ByteArrayInputStream image;//图像   
    private String str;//验证码   
       
   
    private RandomNumUtil(){   
        init();//初始化属性   
    }   
    /*  
     * 取得RandomNumUtil实例  
     */  
    public static RandomNumUtil Instance(){   
        return new RandomNumUtil();   
    }   
    /*  
     * 取得验证码图片  
     */  
    public ByteArrayInputStream getImage(){   
        return this.image;   
    }   
    /*  
     * 取得图片的验证码  
     */  
    public String getString(){   
        return this.str;   
    }   
       
    private void init() {   
        //       在内存中创建图象   
        int width=85, height=20;   
        BufferedImage image = new BufferedImage(width, height, BufferedImage.TYPE_INT_RGB);   
        //       获取图形上下文   
        Graphics g = image.getGraphics();   
        //      生成随机类   
        Random random = new Random();   
        //       设定背景色   
        g.setColor(getRandColor(200,250));   
        g.fillRect(0, 0, width, height);   
        //      设定字体   
        g.setFont(new Font("Times New Roman",Font.PLAIN,18));   
        //       随机产生155条干扰线,使图象中的认证码不易被其它程序探测到   
        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);   
        }   
        //取随机产生的认证码(6位)   
        String sRand="";   
//        for (int i=0;i<6;i++){   
//            String rand=String.valueOf(random.nextInt(10));   
//            sRand+=rand;   
        char selectChar[] = {'0','1','2','3','4','5','6','7','8','9',
          'A','B','C','D','E','F','G','H','I','J','K','L','M','N','O','P','Q','R','S','T','U','V','W','X','Y','Z',
          'a','b','c','d','e','f','g','h','i','j','k','l','m','n','o','p','q','r','s','t','u','v','w','x','y','z'};//所有候选组成验证码的字符,当然也可以用中文的
        for (int i=0;i<6;i++){   
//            String rand=String.valueOf(random.nextInt(10));   
//            sRand+=rand;
               
     int charIndex = (int) Math.floor(Math.random()*62);
     String rand = String.valueOf(selectChar[charIndex]);
     sRand +=selectChar[charIndex];
            // 将认证码显示到图象中   
            g.setColor(new Color(20+random.nextInt(110),20+random.nextInt(110),20+random.nextInt(110)));   
            //      调用函数出来的颜色相同,可能是因为种子太接近,所以只能直接生成   
            g.drawString(rand,13*i+6,16);   
            this.str=sRand;/*   赋值验证码   */  
        }   
        //图象生效   
        g.dispose();   
        ByteArrayInputStream input=null;   
        ByteArrayOutputStream output = new ByteArrayOutputStream();   
        try{   
            ImageOutputStream imageOut = ImageIO.createImageOutputStream(output);   
            ImageIO.write(image, "JPEG", imageOut);   
            imageOut.close();   
            input = new ByteArrayInputStream(output.toByteArray());   
        }catch(Exception e){   
            System.out.println("验证码图片产生出现错误:"+e.toString());   
        }   
           
        this.image=input;/*  赋值图像  */  
    }   
    /*  
     * 给定范围获得随机颜色  
     */  
    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);   
   }   
}


2.配置action,将上述action返回的逻辑结果设置为文件流类型

struct.xml 代码

<action name="rand" class="com.ection.utiltool.VerifyCode">   
		      <result type="stream">   
	               <param name="contentType">image/jpeg</param>   
	               <param name="inputName">inputStream</param>   
		      </result>   
 		</action>

3.写一个测试的html页面,使其请求上面的action,得到返回的图片结果。

 <script type="text/javascript">   
    function changeValidateCode(obj) {   
           //获取当前的时间作为参数,无具体意义   
        var timenow = new Date().getTime();   
           //每次请求需要一个不同的参数,否则可能会返回同样的验证码   
        //这和浏览器的缓存机制有关系,也可以把页面设置为不缓存,这样就不用这个参数了。   
        obj.src="rand.action?d="+timenow;   
    }   
</script>   
  
<img src="rand.action" onclick="changeValidateCode(this)"/>

4.客户端的验证代码。

public class CheckAction extends ActionSupport{   
    private String str;//客户输入的图片验证码   
       
    public String execute(){   
        String str2=(String)(ActionContext.getContext().getSession().get("random"));//取得session保存中的字符串   
        //下面就是将session中保存验证码字符串与客户输入的验证码字符串对比了   
        if(str2.equalsIgnoreCase(this.getStr())){   
            return SUCCESS;   
        }else{   
            return LOGIN;   
        }   
    }   
    public String getStr() {   
        return str;   
    }   
  
    public void setStr(String str) {   
        this.str = str;   
    }   
} 

 

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值