处理表单数据
类pbuilder包含一个静态方法以pbean实例为参数并且根据javabean对象的属性生成html:
package com.devsphere.articles.usingjsf;
public class pbuilder {
public static string tohtml(pbean pbean) {
stringbuffer buf = new stringbuffer();
buf.append("<p align=/"");
buf.append(pbean.getalign());
buf.append("/">");
buf.append("<font size=/"");
buf.append(pbean.getsize());
buf.append("/" color=/"");
buf.append(pbean.getcolor());
buf.append("/"");
object font[] = pbean.getfont();
if (font != null && font.length > 0) {
buf.append(" face=/"");
for (int j = 0; j < font.length; j++) {
if (j > 0)
buf.append(',');
buf.append(font[j]);
}
buf.append("/"");
}
buf.append(">");
if (pbean.isbold())
buf.append("<b>");
if (pbean.isitalic())
buf.append("<i>");
if (pbean.isunderline())
buf.append("<u>");
string s = pbean.gettext();
int n = s.length();
for (int i = 0; i < n; i++) {
char ch = s.charat(i);
switch (ch) {
case '<':
buf.append("<");
break;
case '>':
buf.append(">");
break;
case '&':
buf.append("&");
break;
case '"':
buf.append(""");
break;
default:
buf.append(ch);
}
}
if (pbean.isunderline())
buf.append("</u>");
if (pbean.isitalic())
buf.append("</i>");
if (pbean.isbold())
buf.append("</b>");
buf.append("</font>");
buf.append("</p>");
return buf.tostring();
}
}
文件view.jsp用<jsp:usebean>获得jsf管理的javabean实例,调用pbuilder的tohtml()方法,并输出html结果。jsf的<h:command_hyperlink>标记用于提供一个返回edit.jsp页的超联接:
<%@ taglib prefix="f" uri="http://java.sun.com/jsf/core"; %>
<%@ taglib prefix="h" uri="http://java.sun.com/jsf/html"; %>
<html>
<head>
<title>view</title>
</head>
<body>
<jsp:usebean id="pbean" scope="session"
class="com.devsphere.articles.usingjsf.pbean"/>
<%= com.devsphere.articles.usingjsf.pbuilder.tohtml(pbean) %>
<f:use_faces>
<h:command_hyperlink label="back to editing" href="edit.jsp"/>
</f:use_faces>
</body>
</html>
应用配置
jsf框架有一个用于实现控制器(controller)的服务端小程序(servlet)叫facesservlet,该小程序必须截取所有包含jsf标记的jsp页面的请求。这个小程序在应用描述器文件web.xml中进行配置,并且映射为 /faces/* 的url模式。要激活这个小程序,jsp程序中的路径必须以“faces”开头。应用的主页index.jsp调用response.sendredirect()使浏览器转移到faces/edit.jsp页面:
<% response.sendredirect("faces/edit.jsp"); %>
文件faces-config.xml的路径在描述器文件web.xml中用环境参数进行说明,该描述器文件中还包含了监听器注册以及其他一些用于jsf实现的引用说明。文件web.xml的内容如下所示:
<?xml version="1.0"?>
<!doctype web-app public
"-//sun microsystems, inc.//dtd web application 2.3//en"
"http://java.sun.com/dtd/web-app_2_3.dtd";>
<web-app>
<context-param>
<param-name>javax.faces.application.config_files</param-name>
<param-value>/web-inf/faces-config.xml</param-value>
</context-param>
<context-param>
<param-name>com.sun.faces.savestateinclient</param-name>
<param-value>false</param-value>
</context-param>
<context-param>
<param-name>com.sun.faces.validatexml</param-name>
<param-value>true</param-value>
</context-param>
<listener>
<listener-class>com.sun.faces.config.configlistener</listener-class>
</listener>
<servlet>
<servlet-name>facesservlet</servlet-name>
<servlet-class>javax.faces.webapp.facesservlet</servlet-class>
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>facesservlet</servlet-name>
<url-pattern>/faces/*</url-pattern>
</servlet-mapping>
</web-app>
当第一次生成一个表单时,jsf创建一个称之为组件树(component tree)的对象结构,其中包含用户界面组件以及验证器(validator)注册这些组件等等相关信息。用户提交表单数据时,jsf根据组件树中的信息进行一些操作,如验证用户输入。默认情况下,jsf将组件树作为一个属性存储在session中。一旦应用完成,这种方式能够正常的运行。但是,在进一步开发时,只要你改变了jsf表单(包括添加或者删除界面组件),jsf就会抛出异常,因为在jsp文件被修改时jsf没有废弃过期的组件树。应该把在web.xml中声明的标记savestateinclient设置为真(true)。做了这个修改之后,jsf将序列化组件树并将其存入html表单的隐藏区域中而不再存储在session中。
总结
本文已经介绍了jsf框架的基本特性,演示了如何用jsf标记建立表单。作为预览包,jsf的实现引用ea4还不能部署,但大部分功能是可用的。在jcp组织(java community process)两年多的研究表明,jsf会受到广泛的欢迎,java开发者确实需要一种建立web用户界面的标准标记库和建立定制web组件的标准api
闽公网安备 35060202000074号