JSF在Web开发中的应用.ppt
《JSF在Web开发中的应用.ppt》由会员分享,可在线阅读,更多相关《JSF在Web开发中的应用.ppt(79页珍藏版)》请在三一办公上搜索。
1、第四章 JSF入门,信息类专业课程,西北农林科技大学,主要内容,JSF简介JSF入门JSF标签JSF开发环境,Web开发技术,Web架构用超文本技术(HTML)实现信息与信息的连接;用统一资源定位技术(URI)实现全球信息的精确定位;用新的应用层协议(HTTP)实现分布式的信息共享。静态 动态客户端技术HTML、Java Applets、JavaScript、ActiveX、CSS、DHTML、XHTML服务端技术CGI(Common Gateway Interface)C、C+、Pascal Perl、PythonPHP、ASP、Servlet(JSP)+JavaBean,最新发展,Java
2、 Web框架Struts、Spring MVC、WebWork、TapestryJSFAJAX(Asynchronous JavaScript and XML)XHTML 和 CSS 的标准表示;使用文档对象模型DOM实现动态显示及用户交互;使用 XML、XSLT和XMLHttpRequest进行数据交换及操作;使用 javascript 将所有技术绑定在一起。Agile WebRuby on Rails Python(Django、TurboGears、Pylons),二、JSF简介,什么是JSFJSF的特性JSF与其它框架的比较JSF实现JSF示例,什么是JSF,JavaServer Fa
3、ces(JSF):符合JavaEE5标准的Java Web应用框架。目标:简化开发。JSF提供:标准的编程接口丰富可扩展的组件库一个核心的JSP标记库用来处理事件、执行验证以及其他非UI相关的操作(core)一个标准的HTML标记库来表示UI组件(html)事件驱动模型JSF通过IDE工具支持拖放式开发。,JSF的由来和目标,由来EJB2的失败非官方Web框架的兴起目标简化开发超越现有Web框架试图在不同的角度上提供网页设计人员、应用程序设计人员、组件开发人员解决方案,让不同技术的人员可以彼此合作又不互相干扰,JSF 体系结构,JSF 的主要优势之一就是它既是 Java Web 用户界面标准又
4、是严格遵循模型-视图控制器(MVC)设计模式的框架。用户界面代码(视图)与应用程序数据和逻辑(模型)的清晰分离使 JSF 应用程序更易于管理。为了准备提供页面对应用程序数据访问的 JSF 上下文和防止对页面未授权或不正确的访问,所有与应用程序的用户交互均由一个前端“Faces”servlet(控制器)来处理。,JSF的特性,技术特性 一流的UI组件和事件模型POJO依赖注入(又称控制反转)客户端独立性 使用或者不使用工具 可扩展的导航(类似于Struts导航,注:Page导航)强大的扩展能力(如Shale)完全的集成(如集成Spring、JPA)本地化和易理解性,JSF的特性,市场和商业特性
5、广泛的采用,包括SUN,Oracle,IBM,BEA,Apache,EDS 作为JavaEE 5.0的组成部分 大型第三方组件市场(iLog,Business Objects,Oracle,Sun,IBM)业内领先的工具支持(Sun Java Studio Creator,NetBeans,Oracle JDeveloper,IBM WSAD,BEA Workshop,Exadel Studio),与其它框架的比较(来自TSS),JSF的优势,UI组件(UI-component)事件驱动模式用户界面到业务逻辑的直接映射 程序员和网页设计人员的分工 请求处理生命周期的多阶段划分 全面的用户自定义
6、支持 Web开发的官方标准之一大量的IDE工具支持,JSF实现,JSF是标准实现Sun JSF RIApache MyFaces组件库TomahawkADF Faces(from Oracle)Tobago,JSF示例,第一个JSF程序 请输入您的名称 名称:,二、JSF入门,第一个JSF程序JSF Expression Language 国际化(I18N)Managed Beans数据转换与验证事件处理,第一个JSF程序,JSF开发环境Eclipse WTPJSF插件JSF实现(MyFaces)TomcatManaged-BeanJSP页面Pages Navigation,JSF应用一:输入
7、页面,f:loadBundle basename=messages var=msg/,用于临时加载国际化资源的语言包,输出指定key对应的国际化消息,JSF应用一:输入页面,JSF应用二:开发托管Bean,从作用上看托管Bean类似struts2的Action,但作用模式不同。对于struts2的Action而言,应用通过表单提交方式把请求提交到struts2的Action;但JSF的托管Bean,系统直接将JSF中的UI组件的行为绑定到托管Bean的属性或方法。如:该文本框的行为绑定到login Bean的name属性。该按钮的行为直接绑定到login Bean的valid方法上,JSF应用
8、二:开发托管Bean,public class LoginBean/下面的三个属性都会直接与JSF标签绑定private String name;private String pass;private String err;./该方法被绑定到UI组件(按钮)的action属性public String valid()if(name.equals(“zhangsan),JSF应用三:定义导航规则,JSF以导航规则来决定逻辑视图与物理视图资源之间的对应关系;JSF导航规则可以指定系统从哪个页面开始,以该页面的提交按钮绑定的值作为 逻辑视图;JSF使用标准的配置文件定义导航规则;JSF允许每个表单域
9、单独触发事件,JSF常用的两类事件:ValueChange事件:表单域的值发生改变时触发该事件;Action事件:用户单击按钮或超链接时触发这类事件。,JSF应用三:定义导航规则,/login.jspsuccess/greeting.jspfailure/login.jsp,faces-config-nav.xml,JSF应用四:解读JSF配置,对于大部分JSF初级开发者而言,常作的两件事是:定义托管Bean,配置XML文件。配置核心控制器 Web应用基本上是请求-响应架构,即:用户向Web应用发请求,Web应用处理请求,处理完成后将请求送回客户端。JSF与传统的MVC框架一样,也提供了一个核
10、心控制器负责处理所有用户请求,即,它就是JSF的核心控制器。FacesServlet是一个标准的Servlet,因此,它的配置与普通Servlet没有太大区别,同样是先配置Servlet,再配置Servlet映射的URL,配置文件时web.xml。,JSF应用四:解读JSF配置,FacesServlet1FacesServlet*.jsf,配置FacesServlet的代码片段如下:,上面配置片段指定使用FacesServlet来拦截所有已.jsf结尾的请求,值得注意的是 FacesServlet拦截的URL不一定是*.jsf,完全可以有用户随意指定。如:*.faces、*.do等。,JSF应
11、用四:解读JSF配置,/WEB-INF/faces-config-beans.xml,/WEB-INF/faces-config-nav.xmlclient,:为整个web用于配置参数,JSF应用四:解读JSF配置,JSF有效参数名及其作用如下:,:指示是在客户端(client)还是在服务器端(server)保存UI组件的状态。JSF有保存页面中组件状态的能力,以便在页面被重新显示时记住用户输入的信息。组件状态可以保存在客户端也可保存在服务器端,这取决于 参数的设置值。可能的取值是client 和 server(默认值)。,:该参数指定JSF映射视图资源时的默认后缀名,默认值是.jsp,不需要
12、改变参数的值。,JSF应用四:解读JSF配置,:该参数指定JSF配置文件的存放位置。默认情况下JSF会自动加载位于WEB_INF下的faces-config.xml文件。如果包含多个JSF配置文件,则需要指定该参数,通过逗号分割不同的(相对路径)配置文件;如果只有一个JSF配置文件,且文件为位于WEB_INF下的faces-config.xml,则可以省略该参数。,:该参数指定JSF所管理的生命周期实例的标识符,该参数通常无需修改。,JSF应用四:解读JSF配置,:该参数用于指定是否需要验证自定义组件。当JSF应用中定义了自定义组件、转换器、校验器时,可以设置应用启动时验证这些自定义组件。该参
13、数的值只能是true或false。,:该参数指定是否需要验证JSF应用中的xml文件。,:当状态保存方法设置为server时,控制会话中保存的视图数量,当设置为-1时表示没有限制。,JSF配置文件结构,JSF配置文件根元素都是元素,JSF应用配置总体分为三种:分别针对日常应用开发,UI扩展开发(编写组件,呈现器,转换器或者验证器)和高级开发。最常见的两个元素是::JSF应用中所有托管Bean都在该元素下配置、管理。:该元素用于管理JSF应用的导航规则。,JSF配置文件结构,三、JSF Expression Language,搭配 JSF 标签来使用,是用来存取数据对象的一个简易语言。以#开始,
14、将变量或运算式放置在 与 之间。#userBean.nameEL的变量名也可以程序执行过程中所声明的名称,或是JSF EL预定义的隐含对象。#param.name对于Map类型对象,可以使用.运算符指定key值来取出对应的value,也可以使用 与 来指定。#paramname#someBean.someMapuser.name 如果变量是List类型或阵列的话,则可以在 中指定索引。#someBean.someList0,也可以指定字面常数,对于true、false、字符串、数字,JSF EL会尝试进行转换。在声明变量名称时,要留意不可与JSF的保留字或关键字同名。true false nu
15、ll div mod and or not eq ne lt gt le ge instanceof empty 在EL中可以直接进行一些算术运算、逻辑运算与关系运算。算术运算符:加法(+),减法(-),乘法(*),除法(/or div)与余除(%or mod)三元运算:(expression?result1:result2)逻辑运算:and(或&)、or(或!)、not(或!)关系运算:小于Less-than(or gt)、小于或等于Less-than-or-equal(=or ge)、等于Equal(=or eq)、不等于Not Equal(!=or ne)EL运算符的执行优先顺序与Jav
16、a运算符对应,三、JSF Expression Language,四、国际化信息,JSF的国际化(Internationalization,简写I18N)信息处理是基于Java对国际化的支持,可以在一个信息资源文件中统一管理信息资源,资源文件的名称是.properties,而内容是名称与值的配对。资源文件名称由basename加上语言与地区来组成:basename.properties basename_en.properties basename_zh_CN.properties信息资源文件必须是ISO-8859-1编码,所以对于非西方语系的处理,必须先将之转换为Java Unicode E
17、scape格式:nameText=名称 nameText=u540du79f0 使用标签来指定载入信息资源:,可以设定locale属性,直接指定所要使用的语系:也可以在faces-config.xml中设定语系:zh_CN en.甚至可以让使用者选择自己的语系:,四、国际化信息,五、Managed Beans,JSF使用 Bean 来达到逻辑层与表现层分离的目的,Bean的管理集中在配置文件中,只要修改配置文件,就可以修改Bean之间的相依关系。Backing Bean,Glue Bean:在真正的业务逻辑Bean及UI组件之间搭起桥梁,在Backing Bean中会呼叫业务逻辑Bean处理使
18、用者的请求,或者是将业务处理结果放置其中,等待UI组件取出当中的值并显示结果给使用者。,五、Managed Beans,在faces-config.xml中集中管理作用域:application:一直存活session:会话过程request:请求阶段none:需要时,临时,Managed-Bean类型,Beans的配置与设定,JSF预定义会读取faces-config.xml中关于Bean的定义 可在web.xml中利用javax.faces.CONFIG_FILES参数指定自定义文件:/WEB-INF/beans.xml.定义文件可以有多个,中间以“,”区隔:/WEB-INF/naviga
19、tion.xml,/WEB-INF/beans.xml,Beans的配置与设定,Bean的基本定义:名称 类 存活范围 可选设置属性的初始值 user#user,Beans上的List,someProperty 1 2 3,Beans上的Map,someProperty someKey1 100 someKey2 200,访问Managed Beans,如果要在其它类中取得Bean对象,则可以先取得,它代表了JSF目前的执行环境对象,接着尝试取得对象,从中取得指定的Bean对象:FacesContext context=FacesContext.getCurrentInstance();Val
20、ueBinding binding=context.getApplication().createValueBinding(#user);UserBean user=(UserBean)binding.getValue(context);取得Bean的某个属性:FacesContext context=FacesContext.getCurrentInstance();ValueBinding binding=context.getApplication().createValueBinding(#user.name);String name=(String)binding.getValue(
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- JSF Web 开发 中的 应用

链接地址:https://www.31ppt.com/p-5436385.html