http://stenlylee.iteye.com/blog/317179 学习这位朋友的这篇文章,我在详细写下实现步骤。
首先我的例子环境是hibernate+spring+jsf。
再次,backbean上的代码稍微修改一下,如下
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这个类,
* 我这里直接把随机生成的代码保存session
*/
FacesContext facesContext = FacesContext.getCurrentInstance();
try {
HttpSession session = (HttpSession) facesContext
.getExternalContext().getSession(true);
session.setAttribute("code", code);
} catch (Exception e) {
e.printStackTrace();
}
// 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);
}
}
然后,这bean要写进jsf的配置文件里面
<managed-bean>
<managed-bean-name>validateCodeImageData</managed-bean-name>
<managed-bean-class>
com.express.bb.ImageData
</managed-bean-class>
<managed-bean-scope>request</managed-bean-scope>
</managed-bean>
然后要把生成的随机码显示到jsf页面 这里需要用到richfaces的标签显示,可以去http://www.jboss.org/jbossrichfaces/downloads/这里下包(我用的3.1版本的),当把包导进工程之后,
在web.xml文件中添加以下代码
<!-- 配置richfaces -->
<context-param>
<param-name>org.richfaces.SKIN</param-name>
<param-value>blueSky</param-value>
</context-param>
<filter>
<display-name>RichFaces Filter</display-name>
<filter-name>richfaces</filter-name>
<filter-class>org.ajax4jsf.Filter</filter-class>
</filter>
<filter-mapping>
<filter-name>richfaces</filter-name>
<servlet-name>Faces Servlet</servlet-name>
<dispatcher>REQUEST</dispatcher>
<dispatcher>FORWARD</dispatcher>
<dispatcher>INCLUDE</dispatcher>
</filter-mapping>
最后,就可以在你要显示 的页面加上
<%@ taglib uri="http://richfaces.org/a4j" prefix="a4j"%>
<%@ taglib uri="http://richfaces.org/rich" prefix="rich"%>
<a4j:mediaOutput element="img" cacheable="flase" session="false"
rendered="true" createContent="#{validateCodeImageData.paint}"
value="#{validateCodeImageData}" mimeType="image/jpeg" />
到这里就可以运行一下工程看效果了。
good luck !!
分享到:
相关推荐
- 验证相关的类或配置,用于实现验证码功能。 通过分析这个示例项目,开发者可以学习如何在实际应用中设置JSF的组件、处理事件、进行数据验证,以及如何集成验证码功能以增强安全性。这将对深入理解和掌握JSF框架的...
其中,`<a4j:commandLink>`和`<a4j:mediaOutput>`是实现验证码刷新功能的关键组件。 ### 二、验证码刷新的实现原理 验证码刷新的实现主要依赖于两个方面:一是服务器端的处理逻辑,二是客户端的AJAX请求。在服务器...
在本文中,我们将深入探讨如何将JavaServer Faces (JSF) 框架与Hibernate ORM 和Tiles ...这个登录实例是此类整合的一个基础应用,但你可以根据需求扩展它,例如添加权限控制、验证码功能等,以适应更复杂的业务场景。
JSF 提供了一系列的UI组件,如输入字段、按钮、表格等,这些组件可以帮助开发者更方便地构建登录和注册功能。本资源中的“用jsf做的登录注册的组件”很可能是一个实现了用户身份验证和账户创建的实例,通过JSF技术来...
- **功能**: 提供验证码功能,增加安全性。 - **用途**: 防止自动化工具提交表单,保护网站免受攻击。 #### 5. checkbox - **功能**: 渲染一个HTML复选框。 - **用途**: 实现多选功能,常用于表单中收集用户的偏好...
JSF与模型的交互主要通过Managed Beans实现,这是一个简单的Java类,可以包含业务逻辑和属性,供视图和控制器访问。 4. **控制器(Controller)**: JSF中的控制器主要由事件处理机制完成。当用户操作组件时,会触发...
以下将详细解释如何实现这个功能,以及其中涉及的安全考虑。 首先,我们来看Servlet部分。`ImageServlet`是一个专门处理图片请求的Servlet,它负责读取图片并将其发送到客户端。在`doGet`方法中,Servlet接收四个...
案例中实现的系统功能丰富,涵盖用户登录、图形验证码、用户竞价、物品管理等方面,为读者提供了真实的业务场景,便于将理论知识与实际业务需求结合起来。 总的来说,本书是Java EE企业级应用开发领域的一本实操...
这个库的版本`kaptcha-2.3.jar`提供了方便的API,使得开发者能够轻松地在项目中集成验证码功能。 `kaptcha`库的核心功能包括: 1. **多种验证码样式**:`kaptcha`支持生成各种不同风格的验证码,包括扭曲文字、...
`awt`目录可能包含一个简单的验证码生成器示例,它可能通过生成随机文本、扭曲图像、添加噪声等方法来实现。验证码的生成通常涉及到颜色、字体、形状和随机性等多个因素。 2. **Test**:在软件开发中,测试是必不可...
2.6 jsf框架的实现 2.7 ajax框架的实现 2.8 使用jdbc连接数据库 2.9 小结 第3章 实现各种框架的集成 3.1 spring框架与其他框架的集成原理 3.2 实现ssh三种框架环境集成 3.3 实现spring与...
PrimeFaces作为JSF组件库的扩展,不仅简化了JSF的学习曲线,还提供了大量定制化和增强的功能。它允许开发者通过XML或注解的方式将丰富的客户端和服务器端组件集成到应用中。 安装PrimeFaces 3.5首先需要下载,通常...
"带肖像和验正码的jsp注册页面[代码篇续2]_独霸天下.htm"和"带肖像和验正码的jsp注册页面[代码篇续3]_独霸天下.htm"很可能是两个部分的教程,演示了如何使用DWR实现一个包含图像上传和验证码功能的JSP注册页面,这...
7. **登录功能**:在JavaEE应用中,登录功能通常由Servlet或Filter实现,通过验证用户名和密码来控制用户访问权限。可以使用JDBC直接操作数据库,或者结合JPA来实现数据持久化。另外,为了提高安全性,通常会引入...
下面将详细讨论这些功能及其在JEE环境中的实现。 1. **用户登录**: - 用户登录通常通过HTTP请求进行,前端界面收集用户输入的用户名和密码。 - 后端使用JEE的Servlet或JavaServer Faces (JSF)组件处理登录请求,...
【标题】"基于javaweb的仿照百度网盘做的小型云盘系统"是一个使用Java Web技术实现的项目,旨在模仿百度网盘的功能,提供个人或小团队的在线存储服务。这个系统可能包括了文件上传、下载、分享、管理等功能,用户...
这可以通过使用Servlet、JSP和JavaServer Faces (JSF)等技术实现,配合过滤器进行权限控制。同时,会话管理也是关键,确保用户在登录后能保持状态,直到他们主动登出或超时。 3. **删除操作**:在J2EE应用中,删除...
这种验证码技术的一个开源实现是结合了Pov Ray渲染工具和Java Server Faces (JSF)框架。下面将详细讨论这个开源3D验证码项目以及相关的技术知识点。 首先,Pov Ray是一个强大的基于光线追踪的3D渲染引擎。在3D...
首先,JavaEE(Java企业版)是一个用于构建企业级应用的平台,它包括了多种组件和服务,如Servlet、JSP、EJB、JPA、JSF等。在JavaEE的银行管理系统中,Servlet通常用于处理HTTP请求,实现业务逻辑,而JSP则用于生成...
在实际开发时,还需要考虑系统的安全性,如使用HTTPS协议保护用户隐私,实施角色权限管理防止未授权访问,以及使用验证码防止恶意注册和攻击。同时,为了提高用户体验,需要优化前端性能,如使用Ajax实现局部刷新,...