JSF简介
一、 什么是 JSF:
JavaServer Faces (JSF) 是一种用于构建 Web 应用程序的新标准 Java 框架。它提供了一种以组件为中心来开发 Java Web 用户界面的方法,从而简化了开发。
JavaServer Faces于2004年三月1.0版正式提出,清楚的将Web应用程序的开发者划分了三个角色:网页设计人员、应用程序设计人员以及UI组件开发人员。 从使用的角度来看,网页设计人员与应用程序设计人员可以他们所熟悉的方式开发程序,而不用侵入彼此的工作范围,而UI组件开发人员可以独立的开发个别组件,细节的部份留给了他们来处理。
JSF 还通过将良好构建的模型-视图-控制器 (MVC) 设计模式集成到它的体系结构中,确保了应用程序具有更高的可维护性。
由于 JSF 是通过 Java Community Process (JCP) 开发的一种 Java 标准,因此开发工具供应商完全能够为 JavaServer Faces 提供易于使用的、高效的可视化开发环境。
二、 JSF 体系结构:
JSF 的主要优势之一就是它既是 Java Web 应用程序的用户界面标准又是严格遵循模型-视图-控制器 (MVC) 设计模式的框架。用户界面代码(视图)与应用程序数据和逻辑(模型)的清晰分离使 JSF 应用程序更易于管理。为了准备提供页面对应用程序数据访问的 JSF 上下文和防止对页面未授权或不正确的访问,所有与应用程序的用户交互均由一个前端FacesServlet(控制器)来处理。
三、 JSF 生命周期:
FacesServlet 充当用户和 JSF 应用程序之间的纽带。它在明确限定的 JSF 生命周期(规定了用户请求之间的整个事件流)的范围内工作。
1. 当JSF页面上的一个事件发生时(比如:用户单击了一个按钮),事件通知通过HTTP发往服务器。服务器端使用FacesServet这个特殊的Servlet处理该通知。
2. FacesServlet一接收到用户的请求就创建一个FacesContext对象(JSF上下文,它存放了应用程序的所有数据)。在处理过程中,主要修改的就是这个FaceContext对象。
3. 接着就是处理过程,处理器是一个叫作Lifecycle的对象。FacesServet把控制权转交给Lifecycle对象。该对象分6个阶段来处理FacesContext对象以生成响应,最后将响应发回客户端。
Lifecycle对象处理JSP请求所需要的一系列动作称为请求处理生命周期。过程状态图如下:
由于请求处理生命周期里的应用请求值、处理验证、更新模型值和调用应用程序等阶段都可以在当前的请求对应的FacesContext实例中添加事件,因此,JSF实现必须在这些阶段后处理这些事件。
阶段
|
说明
|
恢复视图
|
为选定的视图找到或创建组件树。
一旦用户单击JSP页面上的链接或按钮,就会启动此阶段。JSF应用里的JSP页面被表示成一个组件树。JSF实现会进一步将这些组件链接到事件处理程序和验证程序,并将视图保存在FacesContext对象中,以备后面的处理过程所用。FacesContext对象包含了JSF用来管理当前会话中当前请求的GUI组件状态所需要的所有状态信息。
|
应用请求值
|
使用请求中发送来的值来更新组件树的组件值。因为请求中发送来的值都是String类型的,所以在更新组件树的组件值之前,必须将这些值转换为相应类型。这个过程也是解码。若转换有错误,这些错误将添加到FacesContext对象。
|
处理验证
|
当每个组件的本地值被更新后,Lifecycle对象都会根据这些注册组件的验证规则来验证这些值的合法性。
如果输入的值不符合验证规则,就会将验证错误添加至FacesContext对象,并将组件标记为无效。JSF将转至呈现响应阶段,并显示带有验证错误消息的视图。
如果没有遇到验证错误,JSF将进入下一阶段。
|
更新模型值
|
更新与组件相关的后台bean(也叫管理bean)或者模型对象的值。只有那些与组件值绑定在一起的Bean属性才会被更新。
|
调用应用程序
|
JSF控制器调用应用程序来处理应用程序级的事件,如提交一个表单。(此阶段可执行业务逻辑)
|
呈现响应
|
使用当前的显示技术(如JSP)显示选定的视图。
|
四、 设置JSF环境:
1. JSF库:
您可以到JSF官方网站的下载区下载其压缩包 :http://java.sun.com/javaee/javaserverfaces/download.html,在下载压缩包并解压缩之后,将其lib目录下的jar 档案复制至您的Web应用程序的/WEB-INF/lib目录下,另外您还需要jstl.jar与standard.jar 文件,这些文件您可以在sample 目录下,解压缩当中的一个范例,在它的/WEB-INF/lib目录下找到,将之一并复制至您的Web应用程序的/WEB-INF/lib目录下。
您总共需要以下的jar文件:
1) jsf-api.jar :定义于JSF规范中的JSF API类。
2) jsf-impl.jar :特定实现的JSF类(不同的实现组织,包名可能不同)。
3) rcommons-digester.jar :解析xml文件的类。
4) commons-collections.jar :提供了基于Java Collection类创建的各种类。
5) commons-beanutils.jar :定义和访问JavaBean组件属性的应用工具。
6) commons-logging.jar :日志工具。
7) jstl.jar :JSTL API类。
8) standard.jar :JSTL 的实现类。
2. 配置:
对所有Java web应用来说,配置开始于Web应用部署描述符。另外,Faces具有自己的扩展配置系统以支持各种附加特征。
1) Servlet配置:
JSF应用需要Servlet,称为FacesSevlet。它是整个应用的前端控制器。所有的请求都通过FacesServlet来处理:
<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns="http://java.sun.com/xml/ns/j2ee"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://java.sun.com/xml/ns/j2ee http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd" version="2.4">
<display-name>guessNumber</display-name>
<servlet>
<servlet-name>Faces Servlet</servlet-name>
<servlet-class>javax.faces.webapp.FacesServlet</servlet-class>
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>Faces Servlet</servlet-name>
<url-pattern>*.faces</url-pattern>
</servlet-mapping>
</web-app>
|
在上面的定义中,我们将所有.faces的请求交由FaceServlet来处理,FaceServlet会唤起相对的.jsp网页,例如请求是/index.faces的话,则实际上会唤起/index.jsp网页,完成以上的配置,您就可以开始使用JSF了。
2) JSF应用配置:
JSF的应用配置文件提供了对整个应用的相关信息的“地图”,它处理诸如导航规则、受管Bean、国际化等。这个文件就放置在应用程序的WEB-INF目录下。
五、 示例及分析:
示例要求:要求用户猜一个0到10之间的数字,第二页告诉用户猜的是否正确,要求检查用户输入的合法性。
步骤:
1. 创建一名为guessNumber的web应用程序。按“设置JSF环境”准备好JSF库。
2. 创建受管Bean(或叫后台Bean):
package chapter5;
import java.util.Random;
public class UserNumberBean {
/** 用户输入的数字 */
private int userNumber = 0;
/** 正确答案数字 */
private int keyNumber = 0;
/** 最小值 */
private int minNum = 0;
/** 最大值 */
private int maxNum = 10;
/** 回应客户的信息字符串 */
private String responseStr;
public UserNumberBean() {
Random random = new Random();
keyNumber = random.nextInt(10);
System.out.println("正确数字是:" + keyNumber);
}
public int getUserNumber() {
return userNumber;
}
public int getKeyNumber() {
return keyNumber;
}
public int getMaxNum() {
return maxNum;
}
public int getMinNum() {
return minNum;
}
public String getResponseStr() {
if(userNumber == keyNumber){
return "您真聪明,您猜对了!";
}else{
return "对不起,您猜错了!不是"+ userNumber +"!";
}
}
public void setUserNumber(int userNumber) {
this.userNumber = userNumber;
}
public void setKeyNumber(int keyNumber) {
this.keyNumber = keyNumber;
}
public void setMaxNum(int maxNum) {
this.maxNum = maxNum;
}
public void setMinNum(int minNum) {
this.minNum = minNum;
}
public void setResponseStr(String responseStr) {
this.responseStr = responseStr;
}
}
|
受管Bean充当控制器的角色:通常它包含想要从用户处收集的属性,以及处理这些属性、操纵UI和执行其他一些应用处理的监听器方法。即它接收用户提交的数据,然后调用相应的模型的业务方法来处理用户的请求。
3. 在JSF的配置文件faces-config.xml(该文件放置在WEB-INF下)中配置受管理的后台Bean:
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE faces-config PUBLIC
"-//Sun Microsystems, Inc.//DTD JavaServer Faces Config 1.1//EN"
"http://java.sun.com/dtd/web-facesconfig_1_1.dtd">
<faces-config xmlns="http://java.sun.com/JSF/Configuration">
<managed-bean>
</managed-bean>
</faces-config>
|
4. 开发基于JSF的用户界面:
建立JSP页面,使用定制标签表示将作为HTML元素用的JSF组件。
第一个页面:猜数页面guess.jsp:
<%@ page contentType="text/html; charset=GBK" %>
<%@ taglib uri="http://java.sun.com/jsf/core" prefix="f" %>
<%@ taglib uri="http://java.sun.com/jsf/html" prefix="h" %>
<html>
<head>
<title>猜数字</title>
</head>
<body bgcolor="#ffffff">
<f:view>
<h:form id="helloForm">
<h2>请猜一个<h:outputText value="#{UserNumberBean.minNum}" />
至<h:outputText value="#{UserNumberBean.maxNum}" />的数字</h2>
<h:inputText id="userNo"
value="#{UserNumberBean.userNumber}">
<f:validateLongRange minimum="#{UserNumberBean.minNum}"
maximum="#{UserNumberBean.maxNum}" />
</h:inputText>
<h:commandButton id="submit" action="success" value="提交" />
<br/>
<h:message style="color:red;" id="errors1" for="userNo"/>
</h:form>
</f:view>
</body>
</html>
|
第二个页面:结果页面response.jsp:
<%@ page contentType="text/html; charset=GBK" %>
<%@ taglib uri="http://java.sun.com/jsf/core" prefix="f" %>
<%@ taglib uri="http://java.sun.com/jsf/html" prefix="h" %>
<html>
<head>
<title>结果</title>
</head>
<body bgcolor="#ffffff">
<f:view>
<h:form id="responseForm">
<h2>
<h:outputText id="result" value="#{UserNumberBean.responseStr}" />
</h2>
<h:commandButton id="back" value="返回" action="success" />
</h:form>
</f:view>
</body>
</html>
|
5. 编写事件监听器或者导航规则:
l 编写事件监听器来决定事件发生时应该有的反应。比如用户单击一个按钮或提交了表单。如果没有事件监听器,在这一步定义页面导航规则。
l 导航规则涉及到定义应用程序中各种页面的跳转。
本例是配置导航规则:在faces-config.xml文件中:
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE faces-config PUBLIC "-//Sun Microsystems, Inc.//DTD JavaServer Faces Config 1.1//EN" "http://java.sun.com/dtd/web-facesconfig_1_1.dtd">
<faces-config xmlns="http://java.sun.com/JSF/Configuration">
<managed-bean>
<managed-bean-name>UserNumberBean</managed-bean-name>
<managed-bean-class>chapter5.UserNumberBean</managed-bean-class>
<managed-bean-scope>session</managed-bean-scope>
</managed-bean>
<navigation-rule>
</navigation-case>
</navigation-rule>
<navigation-rule>
<from-view-id>/response.jsp</from-view-id>
<navigation-case>
<from-outcome>success</from-outcome>
<to-view-id>/guess.jsp</to-view-id>
</navigation-case>
</navigation-rule>
</faces-config>
|
第一个导航规则可以这样理解:从guess.jsp页面出发有个导航规则,它有一个导航案例:就是当结果为“successs”时导航到response.jsp。
注:在导航时,预设都是使用forward的方式,您可以在<navigation-case>中加入一个<redirect/>子元素,让JSF发送HTTP重定向到新的视图。
6. 部署、运行、调试:
六、 JSF的用户界面组件模型:
JavaServer Faces 的真正威力在于它的用户界面组件模型。在该模型中,应用程序完全用组件集合构建,这些组件可以针对多种客户端类型用不同的方式来进行显示。
JSF的用户界面组件模型由UI组件类、显示模型、事件模型、数据置换模型以及数据验证模型组成。
1. UI组件类:与其他专有技术(如 ASP.Net)有点类似,JSF 的 UI 组件模型技术使开发人员能够使用预先构建的用户界面 (UI) 组件来构建 Web 用户界面(而非完全从头构建用户界面),从而提供了前所未有的开发效率。JSF UI 组件有多种形式,可以简单到只是显示文本的 outputLabel,或者复杂到可以表示来自数据集合(如数据库表)的表格化数据的 dataTable。
JavaServer Faces 规范在其参考实施中提供了一组基本 UI 组件,这些组件本身是非常有用的。它们包括两个组件库:
l “HTML”组件库 — 它大部分映射了标准的 HTML 输入元素。
l “Core”组件库 — 它辅助常见的应用程序开发任务(如,国际化和验证/转换输入数据)。
如果在JSP页面中使用HTML和Core组件库,必须在JSP页面中包含下列的taglib指令。
<%@ taglib uri="http://java.sun.com/jsf/core" prefix="f" %>
<%@ taglib uri="http://java.sun.com/jsf/html" prefix="h" %>
|
除了提供一个基本 UI 组件库之外,JSF API 还提供了扩展和创建定制 JSF UI 组件的功能,从而在基本组件之上提供更多功能。
2. 组件显示模型:组件的功能通常围绕着两个动作:解码和编码数据。解码是把进入的请求参数转换成组件的值的过程。编码是把组件的当前值转换成对应的标签(也就是HTML)的过程。
组件显示功能有两种工作实现方式:
l 直接实现:组件自己实现解码和编码。
l 委托实现:组件委托呈现器进行解码和编码。
3. 数据转换模型:提供了各和类和接口,使JSF页面中的文本数据能够转换成原始数据类型。将数据从视图到模型和从模型到视图的所有转换都是由转换模型处理的。
4. 事件和监听器模型:JSF实现由事件和监听器类组成。每当JSF组件激发事件时,就会创建一个事件对象(事件对象包含的信息有页面中哪个组件生成了事件等),而后JSF将调用相应监听器的方法来捕获事件。由JSF组件激发的两个最常见事件是动作事件和值更改事件。
动作事件在组件(按钮和链接)被激活时触发。当用户更改组件(如复选框)的值时将激发值更改事件。
要使组件能够响应动作事件或值更改事件。应用程序可以使用以下技术之一:
3) 实现事件监听器类以处理事件和在组件上注册事件:
4) 在后台Bean的方法中实现事件处理,并在组件的方法绑定表达式中引用此方法。
5. 验证模型:JSF提供了各种类来验证在JSF页面上各个控件中包含的数据。此验证在更新模型中的数据之前进行。使用这些标签进行的验证包括:检查字段中文本的长度和检查字段值是否在指定的范围内等。JSF提供了三种内建验证器,即:<f:validateDoubleRange>、<f:validateLongRange>、<f:validateLength>。使用这些验证器的方法是将它们嵌入到组件标签内,代码如下所示:
<h:inputText id="userNo" value="#{UserNumberBean.userNumber}">
<f:validateLongRange minimum="#{UserNumberBean.minNum}"
maximum="#{UserNumberBean.maxNum}" />
</h:inputText>
|
这段代码要求userNo文本字段中所输入的值要在指定的最小值和最大值之间。
相关推荐
内容概要:本文详细介绍了基于MATLAB GUI界面和卷积神经网络(CNN)的模糊车牌识别系统。该系统旨在解决现实中车牌因模糊不清导致识别困难的问题。文中阐述了整个流程的关键步骤,包括图像的模糊还原、灰度化、阈值化、边缘检测、孔洞填充、形态学操作、滤波操作、车牌定位、字符分割以及最终的字符识别。通过使用维纳滤波或最小二乘法约束滤波进行模糊还原,再利用CNN的强大特征提取能力完成字符分类。此外,还特别强调了MATLAB GUI界面的设计,使得用户能直观便捷地操作整个系统。 适合人群:对图像处理和深度学习感兴趣的科研人员、高校学生及从事相关领域的工程师。 使用场景及目标:适用于交通管理、智能停车场等领域,用于提升车牌识别的准确性和效率,特别是在面对模糊车牌时的表现。 其他说明:文中提供了部分关键代码片段作为参考,并对实验结果进行了详细的分析,展示了系统在不同环境下的表现情况及其潜在的应用前景。
嵌入式八股文面试题库资料知识宝典-计算机专业试题.zip
嵌入式八股文面试题库资料知识宝典-C and C++ normal interview_3.zip
内容概要:本文深入探讨了一款额定功率为4kW的开关磁阻电机,详细介绍了其性能参数如额定功率、转速、效率、输出转矩和脉动率等。同时,文章还展示了利用RMxprt、Maxwell 2D和3D模型对该电机进行仿真的方法和技术,通过外电路分析进一步研究其电气性能和动态响应特性。最后,文章提供了基于RMxprt模型的MATLAB仿真代码示例,帮助读者理解电机的工作原理及其性能特点。 适合人群:从事电机设计、工业自动化领域的工程师和技术人员,尤其是对开关磁阻电机感兴趣的科研工作者。 使用场景及目标:适用于希望深入了解开关磁阻电机特性和建模技术的研究人员,在新产品开发或现有产品改进时作为参考资料。 其他说明:文中提供的代码示例仅用于演示目的,实际操作时需根据所用软件的具体情况进行适当修改。
少儿编程scratch项目源代码文件案例素材-剑客冲刺.zip
少儿编程scratch项目源代码文件案例素材-几何冲刺 转瞬即逝.zip
内容概要:本文详细介绍了基于PID控制器的四象限直流电机速度驱动控制系统仿真模型及其永磁直流电机(PMDC)转速控制模型。首先阐述了PID控制器的工作原理,即通过对系统误差的比例、积分和微分运算来调整电机的驱动信号,从而实现转速的精确控制。接着讨论了如何利用PID控制器使有刷PMDC电机在四个象限中精确跟踪参考速度,并展示了仿真模型在应对快速负载扰动时的有效性和稳定性。最后,提供了Simulink仿真模型和详细的Word模型说明文档,帮助读者理解和调整PID控制器参数,以达到最佳控制效果。 适合人群:从事电力电子与电机控制领域的研究人员和技术人员,尤其是对四象限直流电机速度驱动控制系统感兴趣的读者。 使用场景及目标:适用于需要深入了解和掌握四象限直流电机速度驱动控制系统设计与实现的研究人员和技术人员。目标是在实际项目中能够运用PID控制器实现电机转速的精确控制,并提高系统的稳定性和抗干扰能力。 其他说明:文中引用了多篇相关领域的权威文献,确保了理论依据的可靠性和实用性。此外,提供的Simulink模型和Word文档有助于读者更好地理解和实践所介绍的内容。
嵌入式八股文面试题库资料知识宝典-2013年海康威视校园招聘嵌入式开发笔试题.zip
少儿编程scratch项目源代码文件案例素材-驾驶通关.zip
小区开放对周边道路通行能力影响的研究.pdf
内容概要:本文探讨了冷链物流车辆路径优化问题,特别是如何通过NSGA-2遗传算法和软硬时间窗策略来实现高效、环保和高客户满意度的路径规划。文中介绍了冷链物流的特点及其重要性,提出了软时间窗概念,允许一定的配送时间弹性,同时考虑碳排放成本,以达到绿色物流的目的。此外,还讨论了如何将客户满意度作为路径优化的重要评价标准之一。最后,通过一段简化的Python代码展示了遗传算法的应用。 适合人群:从事物流管理、冷链物流运营的专业人士,以及对遗传算法和路径优化感兴趣的科研人员和技术开发者。 使用场景及目标:适用于冷链物流企业,旨在优化配送路线,降低运营成本,减少碳排放,提升客户满意度。目标是帮助企业实现绿色、高效的物流配送系统。 其他说明:文中提供的代码仅为示意,实际应用需根据具体情况调整参数设置和模型构建。
少儿编程scratch项目源代码文件案例素材-恐怖矿井.zip
内容概要:本文详细介绍了基于STM32F030的无刷电机控制方案,重点在于高压FOC(磁场定向控制)技术和滑膜无感FOC的应用。该方案实现了过载、过欠压、堵转等多种保护机制,并提供了完整的源码、原理图和PCB设计。文中展示了关键代码片段,如滑膜观测器和电流环处理,以及保护机制的具体实现方法。此外,还提到了方案的移植要点和实际测试效果,确保系统的稳定性和高效性。 适合人群:嵌入式系统开发者、电机控制系统工程师、硬件工程师。 使用场景及目标:适用于需要高性能无刷电机控制的应用场景,如工业自动化设备、无人机、电动工具等。目标是提供一种成熟的、经过验证的无刷电机控制方案,帮助开发者快速实现并优化电机控制性能。 其他说明:提供的资料包括详细的原理图、PCB设计文件、源码及测试视频,方便开发者进行学习和应用。
基于有限体积法Godunov格式的管道泄漏检测模型研究.pdf
嵌入式八股文面试题库资料知识宝典-CC++笔试题-深圳有为(2019.2.28)1.zip
少儿编程scratch项目源代码文件案例素材-几何冲刺 V1.5.zip
Android系统开发_Linux内核配置_USB-HID设备模拟_通过root权限将Android设备转换为全功能USB键盘的项目实现_该项目需要内核支持configFS文件系统
C# WPF - LiveCharts Project
少儿编程scratch项目源代码文件案例素材-恐怖叉子 动画.zip
嵌入式八股文面试题库资料知识宝典-嵌⼊式⼯程师⾯试⾼频问题.zip