不说废话了,直接上代码,是我在网上找到的,自己整理的。呵呵。
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";
}
分享到:
相关推荐
WebWork虽然现在已经被Struts2和Spring MVC等更现代的框架取代,但其设计理念和实现方式对于理解现代Web框架的演变过程具有很高的参考价值。如果你是Java Web开发的爱好者,深入研究WebWork源码无疑会增强你的技能,...
在提供的压缩包文件中,"webwork"可能包含了示例项目或源代码,用于演示上述登录逻辑的实现。这些文件可以帮助学习者更直观地看到代码结构和具体实现细节,从而加深对WebWork的理解。通过分析和修改这些代码,初学者...
这个实例是关于如何在WebWork框架下实现用户登录功能的。 首先,我们需要了解WebWork的核心概念。WebWork的核心思想是将业务逻辑、数据模型和用户界面进行解耦,通过Action(控制器)、Model(模型)和JSP(视图)...
6. **国际化与本地化**:WebWork内置了对I18N(国际化)和L10N(本地化)的支持,方便开发者实现多语言应用。 7. **标签库**:WebWork与JSTL等标签库兼容,同时还有自己的标签库,例如`displaytag-1.0`,这是一个...
用到知识是webwork做表现层 spring的事务层,IOC AOP hibernate 数据库的映射 Model view control传说中的三层+service 数据库是sqlserver 2005 更重要的是提供所有的.jar框架包
5. **国际化支持**:WebWork1.4内置了对多语言的支持,通过资源包可以轻松实现应用程序的国际化。 6. **视图渲染**:WebWork使用JSP、FreeMarker或其他模板引擎作为视图技术,通过ActionSupport类和结果类型来决定...
同时,利用拦截器可以实现如登录检查、性能监控等功能。 五、WebWork2.0与其他框架的对比 相比于Struts1,WebWork2.0提供了更优的性能和更灵活的设计。虽然后来WebWork与Struts合并成Struts2,但WebWork2.0的理念和...
WebWork 是一个基于 Java 的开源 MVC(Model-View-Controller)框架,它在早期的 Web 应用开发中非常流行,尤其是在 Struts 1 之前。WebWork 提供了强大的动作(Action)处理、类型转换、拦截器(Interceptor)机制...
1. **WebWork基础**:WebWork的核心概念,如Action、Interceptors(拦截器)、Results和Parameters等,以及它们如何协同工作来实现业务逻辑和视图呈现的分离。理解这些基础概念是掌握WebWork的关键。 2. **MVC模式*...
2. 创建第一个动作:创建一个简单的Java类,继承自com.opensymphony.webwork.Action,并实现execute方法。在execute方法中编写业务逻辑。 3. 映射URL:在actions.xml配置文件中,为这个动作类定义一个路径,使URL能...
- **实例分析**:通过一个简单的登录流程实例来具体分析 WebWork 的工作流程。 - **登录界面**:登录界面 `index.jsp` 采用纯 HTML 编写,包含一个表单 `<form action="/login.action">`,表示该表单提交的目标是 `...
8. 安全与访问控制:WebWork提供安全机制和访问控制管理,例如使用拦截器实现权限控制。 9. 简洁高效的代码:通过IoC和Action设计,降低开发复杂度,提高代码复用。 10. 其他功能:支持异步调用、国际化、文件上传和...
3. 国际化与本地化:WebWork支持多语言环境,方便开发者实现应用的国际化。 4. AJAX支持:WebWork提供了与AJAX集成的能力,可以创建富客户端应用。 5. 动态Action和结果:开发者可以根据不同的条件动态选择执行...
然而,WebWork 2.0通过将框架拆分为WebWork和XWork两部分,实现了更为松散的耦合,极大地提高了框架的适应性和可维护性。XWork主要负责处理业务逻辑和数据操作,而WebWork则专注于MVC架构的实现,这种分工明确的设计...
而`webwork-src-2.2.7.jar` 文件则包含了源代码,这对于开发者来说非常有用,因为可以方便地查看和学习框架的内部实现。 在WebWork 2.2.4+Spring+Hibernate的组合中,我们可以看到WebWork与两个其他流行框架的集成...
拦截器(Interceptor)是WebWork中的另一个重要概念,它可以在Action执行前后进行拦截,从而实现如日志记录、权限检查等功能。拦截器框架为开发者提供了一种灵活的方式来扩展WebWork的功能。 #### 验证框架 ...
2. **Action和ActionForm**:在WebWork2中,Action类是控制器的主要实现,它处理用户请求并调用相应的业务逻辑。ActionForm则作为模型和视图之间的数据载体,用于封装表单提交的数据。 3. **Interceptors(拦截器)...