`

webwork登录验证码的实现

阅读更多

不说废话了,直接上代码,是我在网上找到的,自己整理的。呵呵。

jsp:

<input type="text" name="random" size="5" value=""/><img src="rand.action" onclick="changeValidateCode(this)" title="点击图片刷新验证码"/>

 

js:

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

 

这里说个小插曲,由于我的系统用到了拦截器Interceptor,所有在调用rand.action的时候一直被拦截,结果我在配置文件里面删除了对这个aciton的拦截,就可以顺利运行那个rand的aciton。

 

java代码:

import java.awt.Color;
import java.awt.Font;
import java.awt.Graphics;
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 com.opensymphony.xwork.ActionContext;
import com.opensymphony.xwork.ActionSupport;

  
public class RandomPictureAction extends ActionSupport {   
  
    private static final long serialVersionUID = -6950908478971552308L;      
    private ByteArrayInputStream inputStream;    
    String str;
         
    public String execute() throws Exception {   
           
      // 在内存中创建图象      
       int width = 65, 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 < 4; i++) {      
           String rand = String.valueOf(random.nextInt(10));      
           sRand += rand;      
           // 将认证码显示到图象中      
           g.setColor(new Color(20 + random.nextInt(110), 20 + random      
                    .nextInt(110), 20 + random.nextInt(110)));      
            // 调用函数出来的颜色相同,可能是因为种子太接近,所以只能直接生成      
            g.drawString(rand, 13 * i + 6, 16);      
        }      
         
        // 将认证码存入SESSION      
        ActionContext.getContext().getSession().put("rand", sRand);   
        //this.getRequest().setAttribute("rand", sRand);   
        this.str = sRand;   
        System.out.println("rand="+sRand);   
        // 图象生效      
        g.dispose();      
        ByteArrayOutputStream output = new ByteArrayOutputStream();      
        ImageOutputStream imageOut = ImageIO.createImageOutputStream(output);      
        ImageIO.write(image, "JPEG", imageOut);      
        imageOut.close();      
        ByteArrayInputStream input = new ByteArrayInputStream(output   .toByteArray());      
        this.setInputStream(input);      
        return SUCCESS;   
     }      
         
    /*    
     * 给定范围获得随机颜色    
     */     
    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 void setInputStream(ByteArrayInputStream inputStream) {      
        this.inputStream = inputStream;      
    }      
     
    public ByteArrayInputStream getInputStream() {      
        return inputStream;      
    }

	/**
	 * @return the str
	 */
	public String getStr()
	{
		return str;
	}

	/**
	 * @param str the str to set
	 */
	public void setStr(String str)
	{
		this.str = str;
	}   
}  

 

 

相应的xwork配置文件:

 	<!--用户登陆——验证码-->
    <action name="rand" class="com.payeasy.merchantmanage.action.RandomPictureAction">    
        <result name="success" type="stream">  
        <param name="contentType">image/jpeg</param>     
        <param name="inputName">inputStream</param>  
        </result>  
        <interceptor-ref name="loginStack"/>  
    </action> 

 

最后在提交的登录验证处理类上写入对验证码的校验即可:

			//	取得session保存中的验证码字符串	
			String arandom=(String)(ActionContext.getContext().getSession().get("rand"));
			if(arandom.equals(this.getRandom()))
			{
				vPass = "Y";
			}

 

2
1
分享到:
评论

相关推荐

    webwork源码底层实现

    WebWork虽然现在已经被Struts2和Spring MVC等更现代的框架取代,但其设计理念和实现方式对于理解现代Web框架的演变过程具有很高的参考价值。如果你是Java Web开发的爱好者,深入研究WebWork源码无疑会增强你的技能,...

    webwork 登录逻辑验证(简单)

    在提供的压缩包文件中,"webwork"可能包含了示例项目或源代码,用于演示上述登录逻辑的实现。这些文件可以帮助学习者更直观地看到代码结构和具体实现细节,从而加深对WebWork的理解。通过分析和修改这些代码,初学者...

    webwork登录的实例

    这个实例是关于如何在WebWork框架下实现用户登录功能的。 首先,我们需要了解WebWork的核心概念。WebWork的核心思想是将业务逻辑、数据模型和用户界面进行解耦,通过Action(控制器)、Model(模型)和JSP(视图)...

    webwork

    6. **国际化与本地化**:WebWork内置了对I18N(国际化)和L10N(本地化)的支持,方便开发者实现多语言应用。 7. **标签库**:WebWork与JSTL等标签库兼容,同时还有自己的标签库,例如`displaytag-1.0`,这是一个...

    webwork hibernate spring 实现留言板,远程登录

    用到知识是webwork做表现层 spring的事务层,IOC AOP hibernate 数据库的映射 Model view control传说中的三层+service 数据库是sqlserver 2005 更重要的是提供所有的.jar框架包

    webwork-1.4-src.zip_webwork_webwork s_webwork.zip_webwork1.4.zip

    5. **国际化支持**:WebWork1.4内置了对多语言的支持,通过资源包可以轻松实现应用程序的国际化。 6. **视图渲染**:WebWork使用JSP、FreeMarker或其他模板引擎作为视图技术,通过ActionSupport类和结果类型来决定...

    WebWork2.0讲解说明

    同时,利用拦截器可以实现如登录检查、性能监控等功能。 五、WebWork2.0与其他框架的对比 相比于Struts1,WebWork2.0提供了更优的性能和更灵活的设计。虽然后来WebWork与Struts合并成Struts2,但WebWork2.0的理念和...

    WEBWORK

    WebWork 是一个基于 Java 的开源 MVC(Model-View-Controller)框架,它在早期的 Web 应用开发中非常流行,尤其是在 Struts 1 之前。WebWork 提供了强大的动作(Action)处理、类型转换、拦截器(Interceptor)机制...

    WebWork docs 2 -- webWork 详细的说明文档

    1. **WebWork基础**:WebWork的核心概念,如Action、Interceptors(拦截器)、Results和Parameters等,以及它们如何协同工作来实现业务逻辑和视图呈现的分离。理解这些基础概念是掌握WebWork的关键。 2. **MVC模式*...

    webwork2开发指南

    2. 创建第一个动作:创建一个简单的Java类,继承自com.opensymphony.webwork.Action,并实现execute方法。在execute方法中编写业务逻辑。 3. 映射URL:在actions.xml配置文件中,为这个动作类定义一个路径,使URL能...

    WebWork_开发指南

    - **实例分析**:通过一个简单的登录流程实例来具体分析 WebWork 的工作流程。 - **登录界面**:登录界面 `index.jsp` 采用纯 HTML 编写,包含一个表单 `&lt;form action="/login.action"&gt;`,表示该表单提交的目标是 `...

    WebWork深入浅出.doc

    8. 安全与访问控制:WebWork提供安全机制和访问控制管理,例如使用拦截器实现权限控制。 9. 简洁高效的代码:通过IoC和Action设计,降低开发复杂度,提高代码复用。 10. 其他功能:支持异步调用、国际化、文件上传和...

    webWork

    3. 国际化与本地化:WebWork支持多语言环境,方便开发者实现应用的国际化。 4. AJAX支持:WebWork提供了与AJAX集成的能力,可以创建富客户端应用。 5. 动态Action和结果:开发者可以根据不同的条件动态选择执行...

    webwork.pdf

    然而,WebWork 2.0通过将框架拆分为WebWork和XWork两部分,实现了更为松散的耦合,极大地提高了框架的适应性和可维护性。XWork主要负责处理业务逻辑和数据操作,而WebWork则专注于MVC架构的实现,这种分工明确的设计...

    webwork的jar包

    而`webwork-src-2.2.7.jar` 文件则包含了源代码,这对于开发者来说非常有用,因为可以方便地查看和学习框架的内部实现。 在WebWork 2.2.4+Spring+Hibernate的组合中,我们可以看到WebWork与两个其他流行框架的集成...

    webwork详细讲解.doc

    拦截器(Interceptor)是WebWork中的另一个重要概念,它可以在Action执行前后进行拦截,从而实现如日志记录、权限检查等功能。拦截器框架为开发者提供了一种灵活的方式来扩展WebWork的功能。 #### 验证框架 ...

    webWork2开发指南

    2. **Action和ActionForm**:在WebWork2中,Action类是控制器的主要实现,它处理用户请求并调用相应的业务逻辑。ActionForm则作为模型和视图之间的数据载体,用于封装表单提交的数据。 3. **Interceptors(拦截器)...

Global site tag (gtag.js) - Google Analytics