public class ImageData implements Serializable {
private static final long serialVersionUID = -8161565799237268271L;
private BufferedImage image;
Integer width = 60;
Integer height = 20;
Color bankgroud = new Color(0xFFFFFF);
Color drawColor = new Color(0x000000);
Font textFont = new Font("Comic Sans ms", Font.PLAIN, 18);
String str = "0,a,2,x,e,5,j,7,l,9,1,b,c,d,4,f,g,h,i,6,k,8,m,n,o,p,q,r,s,t,u,v,w,3,y,z";
Random random = new Random();
public void paint(OutputStream out, Object data) throws IOException {
if (data instanceof ImageData) {
// create the image
image = new BufferedImage(width, height, BufferedImage.TYPE_INT_RGB);
Graphics graphics = image.getGraphics();
graphics.setColor(bankgroud);
graphics.fillRect(0, 0, width, height);
graphics.setColor(drawColor);
graphics.drawRect(0, 0, width - 1, height - 1);
graphics.setFont(textFont);
//绘制干扰线
for (int i = 0; i < 160; i++) {
int x = random.nextInt(width);
int y = random.nextInt(height);
int xl = random.nextInt(12);
int yl = random.nextInt(12);
graphics.setColor(getRandColor(100,250));
graphics.drawLine(x, y, x + xl, y + yl);
}
//绘制验证码
graphics.setColor(drawColor);
String code="" ;
String[] array = str.split(",");
for (int i = 0; i < 4; i++) {
String rand = array[random.nextInt(36)];
code += rand;
graphics.drawString(rand, 13 * i + 6, 16);
}
FacesUtil.getSession().setAttribute("code", code);
graphics.dispose();
}
ImageIO.write(image, "JPEG", out);
}
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);
}
}
<a4j:mediaOutput element="img" cacheable="flase" session="false"
rendered="true" createContent="#{validateCodeImageData.paint}"
value="#{validateCodeImageData}" mimeType="image/jpeg">
</a4j:mediaOutput>
<managed-bean>
<managed-bean-name>validateCodeImageData</managed-bean-name>
<managed-bean-class>
com.jxh.common.view.ImageData
</managed-bean-class>
<managed-bean-scope>request</managed-bean-scope>
</managed-bean>
- 大小: 73 KB
分享到:
相关推荐
其中,`<a4j:commandLink>`和`<a4j:mediaOutput>`是实现验证码刷新功能的关键组件。 ### 二、验证码刷新的实现原理 验证码刷新的实现主要依赖于两个方面:一是服务器端的处理逻辑,二是客户端的AJAX请求。在服务器...
使用jsf1.2+spring3.0+hibernate3.3实现集成,利用annotation实现自动对象管理注入,用户表的登录增删改查操作,包括验证码ajax集成,消息机制,国际化处理,自定义转换器,自定义验证器等 qq:38732796 欢迎讨论
- 验证相关的类或配置,用于实现验证码功能。 通过分析这个示例项目,开发者可以学习如何在实际应用中设置JSF的组件、处理事件、进行数据验证,以及如何集成验证码功能以增强安全性。这将对深入理解和掌握JSF框架的...
在本文中,我们将深入探讨如何将JavaServer Faces (JSF) 框架与Hibernate ORM 和Tiles 模板引擎整合,以实现一个完整的登录系统。这个整合实例使用了SQL Server Management Studio Express 数据库来存储用户信息,...
4. **密码重置流程**:实现基于邮箱的密码重置机制,包括生成随机验证码,发送邮件,验证用户身份,以及更新密码的逻辑。 5. **安全措施**:了解如何保护用户信息,例如使用HTTPS进行数据传输,密码的哈希和盐值...
JSF与模型的交互主要通过Managed Beans实现,这是一个简单的Java类,可以包含业务逻辑和属性,供视图和控制器访问。 4. **控制器(Controller)**: JSF中的控制器主要由事件处理机制完成。当用户操作组件时,会触发...
- **功能**: 提供验证码功能,增加安全性。 - **用途**: 防止自动化工具提交表单,保护网站免受攻击。 #### 5. checkbox - **功能**: 渲染一个HTML复选框。 - **用途**: 实现多选功能,常用于表单中收集用户的偏好...
在JSF(JavaServer Faces)应用中,动态显示图片是一种常见的需求,特别是在涉及到用户交互和安全性的场景下。以下将详细解释如何实现这个功能,以及其中涉及的安全考虑。 首先,我们来看Servlet部分。`...
案例中实现的系统功能丰富,涵盖用户登录、图形验证码、用户竞价、物品管理等方面,为读者提供了真实的业务场景,便于将理论知识与实际业务需求结合起来。 总的来说,本书是Java EE企业级应用开发领域的一本实操...
5. 实现验证逻辑,比较用户输入的验证码与服务器端保存的验证码是否一致。 总的来说,`kaptcha-2.3.jar`是一个强大而实用的验证码生成工具,为Java Web应用提供了可靠的安全防护,同时也兼顾了用户体验和开发便利性...
2.6 jsf框架的实现 2.7 ajax框架的实现 2.8 使用jdbc连接数据库 2.9 小结 第3章 实现各种框架的集成 3.1 spring框架与其他框架的集成原理 3.2 实现ssh三种框架环境集成 3.3 实现spring与...
在Java EE中,Struts、Spring MVC或JSF等框架可以用于实现这一模式。 接着,数据库管理是系统的重要组成部分。MySQL或Oracle等关系型数据库常被用来存储房源信息、客户资料、交易记录等。使用JDBC(Java Database ...
1. **Web组件**:JavaEE中的Web组件包括Servlet、JSP(JavaServer Pages)和JSF(JavaServer Faces)。Servlet是JavaEE中的基础,用于处理HTTP请求。JSP将动态代码与HTML结合,使页面设计更为直观。JSF则是一种MVC...
- Captcha:用于防止自动化工具恶意访问的验证码组件。 - Carousel:内容轮播组件。 - Charts:各种图表组件,如PieChart、LineChart、BarChart、DonutChart、BubbleChart等。 组件套件还包括一些表单相关的组件,...
这种验证码技术的一个开源实现是结合了Pov Ray渲染工具和Java Server Faces (JSF)框架。下面将详细讨论这个开源3D验证码项目以及相关的技术知识点。 首先,Pov Ray是一个强大的基于光线追踪的3D渲染引擎。在3D...
`awt`目录可能包含一个简单的验证码生成器示例,它可能通过生成随机文本、扭曲图像、添加噪声等方法来实现。验证码的生成通常涉及到颜色、字体、形状和随机性等多个因素。 2. **Test**:在软件开发中,测试是必不可...
DWR通过提供一套简单的API,使得开发者可以轻松地实现AJAX(Asynchronous JavaScript and XML)功能,从而提高用户体验,使网页交互更加流畅。 在"XML.doc"和"XML.docx"中,可能包含了DWR配置文件的示例或解析。DWR...
Java是用于后端服务开发的语言,而Java Web则特指利用Java技术进行Web应用开发,这包括了使用Servlet、JSP、JavaServer Faces (JSF)、Spring Boot等框架,以及相关的HTTP协议处理和Web服务技术。 【压缩包子文件的...
虽然没有明确指出,但该项目可能使用了如Struts、Spring MVC或JSF等Java Web框架,这些框架可以帮助简化开发过程,提供更好的结构和可维护性。 【数据库管理】 1. **数据库设计**:网上书店系统需要存储书籍信息、...
在实际开发时,还需要考虑系统的安全性,如使用HTTPS协议保护用户隐私,实施角色权限管理防止未授权访问,以及使用验证码防止恶意注册和攻击。同时,为了提高用户体验,需要优化前端性能,如使用Ajax实现局部刷新,...