1、Bean标签库
Bean标签库中标签可以访问已经存在的JavaBean以及它们的属性,还可以
定义新的Bean,把它存放在用户指定的任何范围内,供网页或者其它元素访问,
Bean标签库分为以下三类:
1) 用于访问HTTP请求信息或者JSP隐含对象的Bean标签
a) <bean:cookie>
用于检索发送到服务器端的Cookie,包括以下属性:
id: 定义一个Cookie类型的变量,这个变量又是作为将信息
存放在page范围内的key。
name: 指定Cookie的名字
value: 指定Cookie的默认值,如果name指定的Cookie不存在,
就使用value指定的属性值。
例如: <bean:cookie id="cookie" name="cookieName"
value="defaultValue"/>
先检索名为"cookieName"的Cookie是否存在,如果
存在,就把它的值赋给cookie变量的value值,如果
不存在,cookie变量的值就采用默认值"defaultValue"。
b) <bean:header>
用于检索HTTP请求中的Header信息,包括以下属性:
id: 定义一个存放信息的字符串变量,这个变量又是作为
将信息存放在page范围内的key。
name: 指定要检索的Header中的字段名字
例如: <bean:header id="lang" name="Accept-Language"/>
等于
String value =
(HttpServletRequest)request.getHeader("Accept-Language");
String lang = value;
pageContext.setAttribute("lang",value);
c) <bean: parameter>
用于检索HTTP的请求参数,包括以下属性:
id: 定义一个存放信息的字符串变量,这个变量又是作为
将信息存放在page范围内的key。
name: 指定请求的参数名
value: 指定请求参数的默认值
例如1: <bean:parameter id="arg1" name="testarg"
value="noarg"/>
等于
String temp = request.getParameter("testarg");
if(temp != null){
String arg1 = temp;
pageContext.setAttribute("arg1",temp);
}else{
String arg1 = "noarg";
pageContext.setAttribute("arg1","noarg");
}
例如2: <bean:parameter id="arg2" multiple="yes"
name="testarg" value="noarg"/>
arg2是一个存放所有request请求中参数值的字符串数组。
输出所有的参数值:
<%
for(int i = 0; i < arg2.length; i++){
out.write(arg2[i] + "<br>");
}
%>
d) <bean:page>
用于检索JSP隐含对象(如request、session、response)包括
以下属性:
id: 定义一个引用隐含对象的变量,这个变量又是作为
将信息存放在page范围中的key。
property: 指定隐含对象的名字,可选值包括application、
config、request、response和session。
例如: <bean:page id="this_session" property="session"/>
<bean:write name="this_session" property="creationTime"/>
表示定义了一个"this_session"变量,它引用JSP中
的session隐含对象,接着输出该变量中属性
createTime的值(其实是session中属性createTime的值)。
2) 用于访问Web应用资源的Bean标签
a) <bean:message>
用于输出资源配置文件中的一条信息,<bean:message>标签的bundle
属性指定资源配置文件,它和Struts配置文件中的<message-resources>
元素的key属性匹配。如果没有设置bundle属性,就采用默认的资源配置文件。
Struts配置文件中配置了两个资源配置文件:
<message-resources parameter="ApplicationResources"/>
<message-resources parameter="SpecialResources" key="special"/>
第一个资源配置文件没有指定key属性,因此是默认的资源配置文件,
它的资源文件为ApplicationResources.properties。
第二个资源配置文件指定key属性为"special",它的资源文件
为SpecialResources.properties。
内容: hello=Hello,ereryone!
<bean:message>标签三种使用方式:
a1) <bean:message bundle="special" key="hello"/>
bundle --> <message-resources>中的key
key --> SpecialResources.properties中的hello
注意: 如果<bean:message>中设置了属性bundle,那么
<message-resources>中一定要设置属性key,否则运行
时会报错的。
a2) <bean:message>标签中的属性name指定一个scope中的key,value为
资源配置文件中的key。
例如: <% request.setAttribute("stringBean","hello") %>
<bean:message bundle="special" name="stringBean"/>
hello --> SpecialResources.properties中的hello
a3) 同时指定<bean:message>标签的name和property,name指定
一个JavaBean,property指定JavaBean中的一个get方法,get方法
的返回值就是资源配置文件中的key。例如:
<%
SomeBean bean = new SomeBean();
bean.setName("hello");
request.setAttribute("someBean",bean);
%>
<bean:message bundle="special" name="someBean"
property="name"/>
bundle --> <message-resources>中的key
name --> request中的key(someBean)
property --> bean的getName()
getName()返回值(hello) --> 资源配置文件中key(hello)
b) <bean:resource>
用于检索Web资源的内容,包括以下属性:
id: 定义一个代表Web资源的变量
name: 指定Web资源的路径
input: 如果没有设置input属性,则id属性定义的变量为字符串
类型;如果给input设置了值(可以是任意字符串),则id
属性定义的变量为InputStream类型。
例如: <bean:resource id="resource" name="/testpage1.jsp"/>
resource变量代表"/testpage1.jsp"资源,由于没有设置input
属性,因此resource变量为字符串类型,它的值为testpage1.jsp
的源文件内容。
c) <bean:struts>
用于检索Struts框架内在的对象,如ActionFormBean、ActionForward和
ActionMapping。包括以下属性:
id: 定义一个page范围内的变量,用来引用Struts框架内的对象。
formbean: 指定ActionFormBean对象,和Struts配置文件中的
<form-bean>元素匹配。
forward: 指定ActionForward对象,和Struts配置文件中的
<global-forwards>元素的<forward>子元素匹配。
mapping: 指定ActionMapping对象,和Struts配置文件中的
<action>元素匹配。
注意: 属性id必须和下面三个属性中的一个匹配
例如: <bean:struts id="forward" forward="BeanResources"/>
<bean:write name="forward" property="path"/>
以上代码的用属性id定义了一个"forward"变量,它引用
一个名为"BeanResources"的ActionForward对象,在Struts
文件中,与之匹配的<forward>元素为:
<global-forward>
<forward name="BeanResources" path="/BeanResources.jsp"/>
...
</global-forward>
<bean:write>标签输出ActionForward对象的path属性值
d) <bean:include>
和标准的JSP标签<jsp:include>很相似,都可以用来包含其他Web资源
的内容,区别在于<bean:include>标签把其它Web资源的内容存放在一
个变量中,而不是直接显示在页面上。包括以下属性:
id: 定义一个代表其它Web资源的位置
forward: 指定全局转发的路径,和Struts配置文件中的
<global-forward>元素中的<forward>子元素匹配。
page: 指定相对于当前应用的URL,以"/"开头。
href: 指定完整的URL
例如: <bean:include id="p1" page="/page.jsp"/>
<bean:include id="p2" forward="success"/>
<bean:write name="p1" filter="false"/>
<bean:write name="p2" filter="false"/>
3) 用于定义或者输出JavaBean的Bean标签
a) <bean:define>
用于定义一个变量,属性id指定变量存放在scope中的key,toScope属性指定这个
变量存放的范围,如果没有设置toScope属性,则这个变量存放在page
范围内。给id属性定义的变量赋值有三种方式:
a1) 设置value属性 例如:
<bean:define id="age" value="25"/>
a2) 同时设置name和property属性。name属性指定一个已经存在的
Bean,property指定已经存在的Bean的某个属性,id作为key或者变量。
例如:
<% request.setAttribute("sessionBean",session); %>
<bean:define id="contextBean" name="sessionBean"
property="servletContext"/>
ServletContext Name:
<bean:write name="contextBean"
property="servletContextName"/>
contextBean属于ServletContext类型
a3) 同时设置name和type属性。name属性指定已经存在的JavaBean
,type属性指定这个JavaBean的完整的类名。id作为key或者变量。例如:
<bean:define id="loginForm_copy" name="loginForm"
type="com.briup.web.LoginForm"/>
<bean:write name="loginForm_copy" property="username"/>
该标签会依次在page、request、session和application范围
中根据key(loginForm)来查找LoginForm的对象,也可以通过
属性scope来指定一个查找的范围。
注意: 属性id定义的变量也是LoginForm的对象变量(对象引用)。
b) <bean:write>
用于在页面上输出某个Bean或者其属性的内容。
例如: <bean:write id="length" name="list"/>
<bean:write name="student" property="xh"/>
<bean:write format="#.####" name="employee"
property="salary"/>
<bean:write format="MM-dd-yyyyy hh:mm:ss"
name="now" property="time"/>
注意: 该标签自动会从page、request、session和application
范围中根据name指定的key去查找对应的对象,也可以用
scope属性来限定某个范围。
另外,属性filter: true表示将html中的标记作为普通字符显示
false表示不会把html中的标记作为普通字符显示,默认为true。
c) <bean:size>
用于获得Map、Collection或者数组的长度。包括以下属性:
id: 定义一个Integer类型的变量
name: 指定已经存在的Map、Collection或者数组变量
例如: <bean:size id="length" name="list"/>
<bean:write name="length"/>
2、HTML标签库
该标签库可以和标准的HTML标记完成相同的功能,主要分为以下几类:
1) 用于生成基本的HTML的标签
a) <html:html>
用于在页面的开头生成HTML的<html>元素,该标签有一个属性
lang来显示用户显示的语言。
例如: <html:html lang="true"/>
如果用户的浏览器使用中文,那么该代码在运行时被解析为
<html lang="zh-CN">
b) <html:base>
用于在页面的<head>部分生成<base>元素,用于生成当前页面
的绝对URL路径。
例如: <html:base="http://localhost:8080/jsp"/>
那么使用该base的页面已经将URL定位到应用程序jsp
的根目录下面,要从该页面再去访问其它资源,只要
使用相对路径即可。
c) <html:link>
用于生成HTML的<a>元素,包括以下的属性:
forward: 指定全局的转发链接,对应于Struts配置文件中
的<global-forwards>元素
href: 指定完整的URL链接
page: 指定相对于当前应用的URL
例如:
c1) <html:link forward="index">
Link to Global ActionForward
</html:link>
index对应于struts-config.xml中:
全局: <forward name="index" path="index.jsp">
上述标签会自动生成HTML代码:
<a href="/app/index.jsp">
Link to Global ActionForward
</a>
c2) <html:link href="http://localhost:8080/app/index.jsp">
Generate an "href" link
</html>
生成的HTML代码如下:
<a href="http://localhost:8080/app/index.jsp">
Generate an "href" link
</a>
c3) <html:link page="/login.do">
A relative link
</html:link>
生成的HTML代码如下:
<a href="/app/login.do">
Generate an "href" link
</a>
使用该标签的优点:
b1) 应许再URL中以多种方式包含请求参数
b2) 在当前浏览器关闭Cookie时,会自动重写URL,把
jsessionid作为请求参数包含在URL中,用于跟踪
用户的状态(除了href属性)。
d) <html:img>
用于在HTML中嵌入图片
例如:
d1) <html:img page="/girl.gif"/>
生成HTML代码如下:
<img src="/app/girl.gif"/>
d2) <html:img src="/app/girl.gif"
paramId="orderid" paramName="3"/>
生成HTML代码如下:
<img src="/app/girl.gif?orderid=3"/>
2) 用于生成HTML表单的标签
a) <html:form>
生成HTML<form>元素
例如: <html:form action="/login">
生成的HTML代码如下:
<form name="loginForm" method="POST"
action="/app/login.do">
对应于struts-config.xml中部分代码:
<action path="/login"
type="com.briup.web.action.LoginAction"
name="loginForm"
scope="request"
input="/login.jsp"
validate="true">
<forward name="success" path="/member_activity.jsp"/>
</action>
b) <html:text>
生成HTML<input type="text">元素
例如: <html:text property="age"/>
property属性指定的字段和ActionForm中的属性匹配
生成HTML代码如下:
<input type="text" name="age"
value="ActionForm中属性age的值"/>
c) <html:hidden>
生成HTML<input type="hidden">元素
例如: <html:hidden property="age"/>
生成HTML代码如下:
<input type="hidden" name="age" value="同上"/>
d) <html:submit>
生成HTML<input type="submit">元素
例如: <html:submit>提交</html:submit>
生成HTML代码如下:
<input type="submit" name="submit" value="提交"/>
e) <html:cancel>
在表单上生成取消按钮
例如: <html:cancel>Cancel</html:cancel>
生成HTML代码如下:
<input type="submit"
name="org.apache.struts.taglib.html.CANCEL"
value="Cancel"/>
注意: 在Action类中,应该以编程的方式来处理取消事件。
f) <html:reset>
生成HTML<input type="reset">元素
例如: <html:reset>重置</html:reset>
生成HTML代码如下:
<input type="reset" name="reset" value="重置"/>
g) <html:checkbox> 生成HTML<input type="checkbox">元素
h) <html:multibox> 在表单上生成复选框元素
i) <html:radio> 生成HTML<input type="radio">元素
j) <html:select> 生成HTML<select>元素
k) <html:option> 生成HTML<option>元素
l) <html:options> 生成一组HTML<option>元素
m) <html:optionsCollection> 生成一组HTML<option>元素
n) <html:file> 实现将本地文件上传到服务器端
<html:form action="sendFile.do" method="POST"
enctype="multipart/form-data">
<html:file property="file"/>
</html:form>
使用注意: n1) <html:file>必须嵌套在<html:form>中
n2) <html:form>标签的method属性必须为"POST"
n3) <html:form>标签的编码类型enctype必须设置
为"multipart/form-data"
n4) <html:file>标签必须设置property属性,这个
属性和ActionForm中FormFile类型的属性对应。
在ActionForm中必须配置:
private FormFile file;
public FormFile getFile(){return file;}
public void setFile(FormFile file){this.file = file;}
在Action中的处理:
FormFile file = registerForm.getFile();
//获得上传文件的名字
String fname = file.getFileName();
//从file中获得输入流
InputStream is = file.getInputStream();
//构造一个输出流,并指定上传文件在服务器端存放路径
OutputStream os = new FileOutputStream(dir + "/" + fname);
//从is中读取字节流后写入到os中
注意: 上述标签要使用在<html:form>标签中,但是在<html:form>标签中也可以使用标准的
html标记(如:<input type="text"/>等)。
3) 显示错误或者正常消息的标签
a) <html:errors>
该标签在request和session范围内查找ActionMessages或者
子类ActionErrors的对象,再从中读取ActionMessage对象,
把ActionMessage对象中封装的的错误消息显示在页面上。
该标签处理类获取ActionMessages对象的代码如下:
ActionMessages errors =
TagUtils.getInstance().getActionMessages(pageContext,name);
参数name指定ActionMessages对象存放在request和session
范围中的key,默认值为Globals.ERROR_KEY。
在ActionForm和Action中都可以生成ActionMessages对象,在
ActionForm中的validate()验证方法返回ActionErrors对象,Struts的
控制组件RequestProcessor把ActionErrors对象存放在request范围内,
存放时的key为Globals.ERROR_KEY
(如: request.setAttribute(Globals.ERROR_KEY,errors))。
<html:errors>标签中包括的属性:
name: 指定ActionMessages对象存放在request或者session范围
中的key,默认值为Globals.ERROR_KEY。
property: 指定显示消息的属性,若没有设置,将显示ActionMessages
对象中所有的ActionMessage。
bundle: 指定资源配置文件,如果没有设置此项,将从Web应用
默认的资源配置文件中获得消息。
语法: errors.add(消息属性,消息);
如: errors.add(ActionMessages.GLOBAL_MESSAGE,
new ActionMessage("error.error1"));
errors.add(ActionMessages.GLOBAL_MESSAGE,
new ActionMessage("error.error2"));
saveErrors(request,errors);
注意: 同一个消息属性可以对应多条消息
使用<html:errors>的三种方法:
a1) 显示全局消息
全局消息指的是不和特定表单字段关联的消息,消息属性为
ActionMessages.GLOBAL_MESSAGE。设置方式:
errors.add(ActionMessages.GLOBAL_MESSAGE,
new ActionMessage("error.global"));
ActionMessages.GLOBAL_MESSAGE是一个常量,它的值为
org.apache.struts.action.GLOBAL_MESSAGE,代表全局消息。
在页面中显示该消息的方式:
<html:errors property="org.apache.struts.action.GLOBAL_MESSAGE"/>
2) 显示所有的消息
如果在<html:errors/>标签中没有设置property属性,将显示
ActionMessages对象中所有的消息。页面中显示消息方式:
<html:errors bundle="special"/>
指定了特定的资源配置文件,在struts-config.xml文件中
配置为:<message-resources parameter="SpecialErrors"
key="special"/>
3) 显示和特定表单字段关联的消息
errros.add("name",new ActionMessage("error.name"));
页面中显示消息方式:
<html:errors property="name" bundle="special"/>
b) <html:messages>
和<html:errors>相似,也在页面上来显示消息,
使用例子:
<html:messages id="message" name="key" message="true">
<bean:write name="message"/>
</html:messages>
该标签包括以下属性:
name: 指定ActionMessages对象存放在request或者session中
的key。标签处理类将根据这一属性key来检索request
或者session范围的ActionMessages对象。
message: 指定消息的来源。如果为true,则从request或者
session范围内检索出属性key为Globals.MESSAGE_KEY
的ActionMessages对象,此时属性name无效;如果
为false,则根据属性name来检索ActionMessages对象,
如果此时没有设置name属性,将采用默认值Globals.ERROR_KEY。
message属性的默认值为false。
id: 用来命名从消息集合中检索出的每个ActionMessage对象,
它和<bean:write>标签的name属性匹配。在上述例子中,
<html:messages>标签的处理类每次从消息集合中取出一个
ActionMessage对象,并通过id把它命名为"message",
<bean:write>标签接着把这个名为"message"的ActionMessage
对象的消息输出到页面上。
ActionMessages messages = new ActionMessages();
messages.add(ActionMessages.GLOBAL_MESSAGE,
new ActionMessage("error.error1"));
saveMessages(request,messages);
protected void saveMessages(HttpServletRequest request,
ActionMessages messages){
...
request.setAttribute
(Globals.MESSAGE_KEY,messages);
}
3、Logic标签库
该标签库中的标签可以根据特定的逻辑条件来控制输出页面的内容,或者
循环遍历集合中所有的元素。Logic标签库中的标签分为以下几类:
1) 进行比较运算的Logic标签
a) <logic:equal> 比较变量是否等于指定的常量
例如:
a1) <% request.setAttribute("number",new Integer(100));%>
<logic:equal name="number" value="100">
The value of number is 100
</logic:equal>
a2) <%
Student student = new Student();
stu.setName("jack");
request.setAttribute("student",student);
%>
<logic:equal name="student" property="name"
value="jack">
The name of student is jack
</logic:equal>
b) <logic:notEqual> 比较变量是否不等于指定的常量
c) <logic:greaterEqual> 比较变量是否大于或者等于指定的常量
d) <logic:greaterThan> 比较变量是否大于指定的常量
e) <logic:lessEqual> 比较变量是否小于或者等于指定的常量
f) <logic:lessThan> 比较变量是否小于指定的常量
2) 进行字符串匹配的Logic标签
a) <logic:match> 判断变量中是否包含指定的常量字符串
例如:
<% request.setAttribute("username","jackWang")%>
<logic:match name="username" scope="request"
value="jack">
match is right!
</logic:match>
b) <logic:notMatch> 判断变量中是否不包含指定的常量字符串
3) 判断指定内容是否存在的Logic标签
a) <logic:empty> 判断指定的变量是否为null或者为""。
例如: <%
request.setAttribute("emptyString","");
或者
request.setAttribute("emptyString",null);
%>
<logic:empty name="emptyString">
The vlaue of emptyString is empty
</logic:empty>
b) <logic:notEmpty> 判断指定的变量是否不为null或者不是""。
c) <logic:present> 判断指定的安全角色、用户、Cookie、HTTP
请求Header或者JavaBean是否存在。
d) <logic:notPresent> 判断指定的安全角色、用户、Cookie、HTTP
请求Header或者JavaBean是否不存在。
e) <logic:messagesPresent> 判断指定的消息是否存在
f) <logic:messagesNotPresent> 判断指定的消息是否不存在
4) 进行循环遍历的Logic标签
<logic:iterate>是Logic标签库中最复杂的标签,也是用途最广
的一个标签,它能够在一个循环中遍历数组、Collection、Enumeration
Iterator或者Map中的所有元素。
a) 遍历数组
<%
String[] colors =
new String[]{"red","yellow","green"};
List list = new ArrayList();
list.add("a");
list.add("b")
Map map = new HashMap();
map.put("1","a");
map.put("2","b");
request.setAttribute("colors",colors);
request.setAttribute("list",list);
request.setAttribute("map",map);
%>
<logic:iterate id="color" name="colors">
<bean:write name="color"/>
</logic:iterate>
b) 遍历Collection
<logic:iterate id="element" name="list" scope="page|request|session|applicatoin">
<bean:write name="element"/>
</logic:iterate>
c) 遍历Map
<logic:iterate id="entry" indexId="index"
name="map" scope="page|request|session|applicatoin">
<bean:write name="entry" property="key"/>
<bean:write name="entry" property="value"/>
</logic:iterate>
属性scope省去不写,默认从page、request、session和application查找
5) 进行请求转发或者重定向的Logic标签
a) <logic:forward> 进行请求转发
例如: <logic:forward name="index"/>
属性name指定的值为请求转发的全局目标资源,与Struts配置
文件中的<global-forward>元素中的<forward>子元素匹配。
<global-forwards>
<forward name="index" path="/index.jsp"/>
...
</global-forwards>
b) <logic:redirect> 进行请求重定向
它包括forward、href和page三个属性,这三个属性的使用
方法和<html:link>标签中forward、href和page属性的用法很相似。
例如: <logic:redirect href="http://localhost:8080/app/index.jsp"/>