Struts1 标签库

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"/>

posted on 2015-11-23 15:34  chenjingyu  阅读(362)  评论(0编辑  收藏  举报

导航