<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    jimphei學習工作室

    jimphei學習工作室

      BlogJava :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理 ::
      23 隨筆 :: 0 文章 :: 1 評論 :: 0 Trackbacks

    2009年11月22日 #

    import java.util.Map;

    import org.apache.velocity.app.VelocityEngine;
    import org.springframework.ui.velocity.VelocityEngineUtils;

    public class MsgBean ...{
        private VelocityEngine velocityEngine;

        private String msg;

        private Map model; // 用來保存velocity中的參數值

        private String encoding; // 編碼

        private String templateLocation; // 注入的velocity模塊

        public String getEncoding() ...{
            return encoding;
        }

        public void setEncoding(String encoding) ...{
            this.encoding = encoding;
        }

        public String getTemplateLocation() ...{
            return templateLocation;
        }

        public void setTemplateLocation(String templateLocation) ...{
            this.templateLocation = templateLocation;
        }

        public Map getModel() ...{
            return model;
        }

        public void setModel(Map model) ...{
            this.model = model;
        }

        public String getMsg() ...{
            // return title;
            // 將參數值注入到模塊后的返回值
            return VelocityEngineUtils.mergeTemplateIntoString(velocityEngine,
                    templateLocation, encoding, model);

        }

        public void setMsg(String msg) ...{
            this.msg = msg;
        }

        public VelocityEngine getVelocityEngine() ...{
            return velocityEngine;
        }

        public void setVelocityEngine(VelocityEngine velocityEngine) ...{
            this.velocityEngine = velocityEngine;
        }

    }

    <?xml version="1.0" encoding="UTF-8"?>
    <beans xmlns="http://www.springframework.org/schema/beans"
           xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
           xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-2.0.xsd">

     

       
     <bean id="velocityEngine" class="org.springframework.ui.velocity.VelocityEngineFactoryBean"> 
       <property name="resourceLoaderPath">
                <value>classpath:velocity</value>
         </property>
        <property name="velocityProperties">
                     <props>
                           <prop key="resource.loader">class</prop>
                           <prop key="class.resource.loader.class">
                                 org.apache.velocity.runtime.resource.loader.ClasspathResourceLoader
                           </prop>
                           <prop key="velocimacro.library"></prop>
                           <prop key="input.encoding">GBK</prop>
                           <prop key="output.encoding">GBK</prop>
                           <prop key="default.contentType">text/html; charset=GBK</prop>
                     </props>
               </property>
    </bean>

    <bean id="msgBean" class="MsgBean">
            <property name="templateLocation" value="test.vm"></property>
            <property name="encoding" value="GBK"></property>
            <property name="velocityEngine" ref="velocityEngine"></property>
    </bean>


    </beans>

    import java.io.File;
    import java.io.IOException;
    import java.util.HashMap;
    import java.util.Map;

    import org.apache.commons.io.FileUtils;
    import org.springframework.context.ApplicationContext;
    import org.springframework.context.support.ClassPathXmlApplicationContext;


    public class TestVeloctiy ...{
        public static void main(String[] args) ...{
            // TODO Auto-generated method stub
            ApplicationContext ctx=new ClassPathXmlApplicationContext("test3.xml");
            MsgBean    msgBean=((MsgBean)ctx.getBean("msgBean"));
            Map<String, String> data = new HashMap<String, String>();
            data.put("me","yourname");
            msgBean.setModel(data);
            System.out.println(msgBean.getMsg());
           
            
            //根據apache common IO 組件直接將內容寫到一個文件中去.
             File dest = new File( "test.html" );         
              try ...{
                FileUtils.writeStringToFile( dest, msgBean.getMsg(), "GBK" );
            } catch (IOException e) ...{
                // TODO Auto-generated catch block
                e.printStackTrace();
            }

        }
    }

    本文來自CSDN博客,轉載請標明出處:http://blog.csdn.net/pengchua/archive/2008/01/17/2049490.aspx

    posted @ 2009-11-26 11:36 jimphei 閱讀(1148) | 評論 (0)編輯 收藏

    引用自:http://blog.csdn.net/axzywan/archive/2008/07/12/2643921.aspx

    取Session中的值

    <c:out value="${sessionScope.user.userId}"></c:out><br>  

    <c:out value="${user.userLoginName}"></c:out><br>    

    <s:property value="#session.user.userId"/><br>  

    ${session.user.userId}<br> 

    ${sessionScope.user.userId}<br>

    OGNL

    OGNL 是Object Graph Navigation Language 的簡稱,詳細相關的信息可以參考:http://www.ognl.org 。這里我們只涉及Struts2 框架中對OGNL 的基本支持。

     

    OGNL 是一個對象,屬性的查詢語言。在OGNL 中有一個類型為Map 的Context (稱為上下文),在這個上下文中有一個根元素(root ),對根元素的屬性的訪問可以直接使用屬性名字,但是對于其他非根元素屬性的訪問必須加上特殊符號# 。

     

    在Struts2 中上下文為ActionContext ,根元素位Value Stack (值堆棧,值堆棧代表了一族對象而不是一個對象,其中Action 類的實例也屬于值堆棧的一個)。ActionContext 中的內容如下圖:

                  |

                  |--application

                  |

                  |--session

    context map---|

                   |--value stack(root)

                  |

                  |--request

                  |

                  |--parameters

                  |

                  |--attr (searches page, request, session, then application scopes)

                  |

    因為Action 實例被放在Value Stack 中,而Value Stack 又是根元素(root )中的一個,所以對Action 中的屬性的訪問可以不使用標記# ,而對其他的訪問都必須使用# 標記。

     

    引用Action 的屬性

    <s:property value="postalCode"/>

    ActionContext 中的其他非根(root )元素的屬性可以按照如下的方式訪問:

    <s:property value="#session.mySessionPropKey"/> or

    <s:property value="#session["mySessionPropKey"]"/> or

    <s:property value="#request["mySessionPropKey"]/>

     

    Action 類可以使用ActionContext 中的靜態方法來訪問ActionContext 。

    ActionContext.getContext().getSession().put("mySessionPropKey", mySessionObject);

     

    OGNL 與Collection (Lists ,Maps ,Sets )

     

    生成List 的語法為: {e1,e2,e3}.

    <s:select label="label" name="name"

    list="{'name1','name2','name3'}" value="%{'name2'}" />

    上面的代碼生成了一個HTML Select 對象,可選的內容為: name1 ,name2 ,name3 ,默認值為:name2 。

     

    生成Map 的語法為:#{key1:value1,key2:value2}.

    <s:select label="label" name="name"

    list="#{'foo':'foovalue', 'bar':'barvalue'}" />

    上面的代碼生成了一個HTML Select 對象,foo 名字表示的內容為:foovalue ,bar 名字表示的內容為:barvalue 。

     

    判斷一個對象是否在List 內存在:

    <s:if test="'foo' in {'foo','bar'}">

       muhahaha

    </s:if>

    <s:else>

       boo

    </s:else>

     

    <s:if test="'foo' not in {'foo','bar'}">

       muhahaha

    </s:if>

    <s:else>

       boo

    </s:else>

     

    取得一個List 的一部分:

    ?   –   所有滿足選擇邏輯的對象

    ^   -    第一個滿足選擇邏輯的對象

    $   -    最后一個滿足選擇邏輯的對象

    例如:

    person.relatives.{? #this.gender == 'male'}

    上述代碼取得這個人(person )所有的男性(this.gender==male )的親戚(relatives)

     

     

    Lambda 表達式

     

    OGNL 支持簡單的Lambda 表達式語法,使用這些語法可以建立簡單的lambda 函數。

     

    例如:

    Fibonacci:

    if n==0 return 0;

    elseif n==1 return 1;

    else return fib(n-2)+fib(n-1);

    fib(0) = 0

    fib(1) = 1

    fib(11) = 89

     

    OGNL 的Lambda 表達式如何工作呢?

    Lambda 表達式必須放在方括號內部,#this 表示表達式的參數。例如:

    <s:property value="#fib =:[#this==0 ? 0 : #this==1 ? 1 : #fib(#this-2)+#fib(#this-1)], #fib(11)" />

     

    #fib =:[#this==0 ? 0 : #this==1 ? 1 : #fib(#this-2)+#fib(#this-1)] 定義了一個Lambda 表達式,

    #fib(11) 調用了這個表達式。

     

    所以上述代碼的輸出為:89

     

    在JSP2.1 中# 被用作了JSP EL (表達式語言)的特殊記好,所以對OGNL 的使用可能導致問題,

    一個簡單的方法是禁用JSP2.1 的EL 特性,這需要修改web.xml 文件:

    <jsp-config>

        <jsp-property-group>

          <url-pattern>*.jsp</url-pattern>

          <el-ignored>true</el-ignored>

        </jsp-property-group>

    </jsp-config>

    關于EL表達式語言的簡單總結
     

    基本語法

    一、EL簡介
      1.語法結構
        ${expression}
      2.[]與.運算符
        EL 提供.和[]兩種運算符來存取數據。
        當要存取的屬性名稱中包含一些特殊字符,如.或?等并非字母或數字的符號,就一定要使用 []。例如:
            ${user.My-Name}應當改為${user["My-Name"] }
        如果要動態取值時,就可以用[]來做,而.無法做到動態取值。例如:
            ${sessionScope.user[data]}中data 是一個變量
      3.變量
        EL存取變量數據的方法很簡單,例如:${username}。它的意思是取出某一范圍中名稱為username的變量。
        因為我們并沒有指定哪一個范圍的username,所以它會依序從Page、Request、Session、Application范圍查找。
        假如途中找到username,就直接回傳,不再繼續找下去,但是假如全部的范圍都沒有找到時,就回傳null。
        屬性范圍在EL中的名稱
            Page         PageScope
            Request         RequestScope
            Session         SessionScope
            Application     ApplicationScope
           
    二、EL隱含對象
      1.與范圍有關的隱含對象
      與范圍有關的EL 隱含對象包含以下四個:pageScope、requestScope、sessionScope 和applicationScope;
      它們基本上就和JSP的pageContext、request、session和application一樣;
      在EL中,這四個隱含對象只能用來取得范圍屬性值,即getAttribute(String name),卻不能取得其他相關信息。
     
      例如:我們要取得session中儲存一個屬性username的值,可以利用下列方法:
        session.getAttribute("username") 取得username的值,
      在EL中則使用下列方法
        ${sessionScope.username}

      2.與輸入有關的隱含對象
      與輸入有關的隱含對象有兩個:param和paramValues,它們是EL中比較特別的隱含對象。
     
      例如我們要取得用戶的請求參數時,可以利用下列方法:
        request.getParameter(String name)
        request.getParameterValues(String name)
      在EL中則可以使用param和paramValues兩者來取得數據。
        ${param.name}
        ${paramValues.name}

      3.其他隱含對象
     
      cookie
      JSTL并沒有提供設定cookie的動作,
      例:要取得cookie中有一個設定名稱為userCountry的值,可以使用${cookie.userCountry}來取得它。

      header和headerValues
      header 儲存用戶瀏覽器和服務端用來溝通的數據
      例:要取得用戶瀏覽器的版本,可以使用${header["User-Agent"]}。
      另外在鮮少機會下,有可能同一標頭名稱擁有不同的值,此時必須改為使用headerValues 來取得這些值。

      initParam
      initParam取得設定web站點的環境參數(Context)
      例:一般的方法String userid = (String)application.getInitParameter("userid");
        可以使用 ${initParam.userid}來取得名稱為userid

      pageContext
      pageContext取得其他有關用戶要求或頁面的詳細信息。
        ${pageContext.request.queryString}         取得請求的參數字符串
        ${pageContext.request.requestURL}         取得請求的URL,但不包括請求之參數字符串
        ${pageContext.request.contextPath}         服務的web application 的名稱
        ${pageContext.request.method}           取得HTTP 的方法(GET、POST)
        ${pageContext.request.protocol}         取得使用的協議(HTTP/1.1、HTTP/1.0)
        ${pageContext.request.remoteUser}         取得用戶名稱
        ${pageContext.request.remoteAddr }         取得用戶的IP 地址
        ${pageContext.session.new}             判斷session 是否為新的
        ${pageContext.session.id}               取得session 的ID
        ${pageContext.servletContext.serverInfo}   取得主機端的服務信息

    三、EL運算符
      1.算術運算符有五個:+、-、*或$、/或div、%或mod
      2.關系運算符有六個:==或eq、!=或ne、<或lt、>或gt、<=或le、>=或ge
      3.邏輯運算符有三個:&&或and、||或or、!或not
      4.其它運算符有三個:Empty運算符、條件運算符、()運算符
        例:${empty param.name}、${A?B:C}、${A*(B+C)}
     
    四、EL函數(functions)。
      語法:ns:function( arg1, arg2, arg3 …. argN)
      其中ns為前置名稱(prefix),它必須和taglib 指令的前置名稱一置

    ---------------------------------------------

    補充:

    <%@ taglib prefix="c" uri="http://java.sun.com/jstl/core_rt " %>

    FOREACH:

    <c:forEach items="${messages}"
    var="item"
    begin="0"
    end="9"
    step="1"
    varStatus="var">
    ……
    </c:forEach>


    OUT:

    <c:out value="${logininfo.username}"/>
    c:out>將value 中的內容輸出到當前位置,這里也就是把logininfo 對象的
    username屬性值輸出到頁面當前位置。
    ${……}是JSP2.0 中的Expression Language(EL)的語法。它定義了一個表達式,
    其中的表達式可以是一個常量(如上),也可以是一個具體的表達語句(如forEach循環體中
    的情況)。典型案例如下:
    Ø ${logininfo.username}
    這表明引用logininfo 對象的username 屬性。我們可以通過“.”操作符引
    用對象的屬性,也可以用“[]”引用對象屬性,如${logininfo[username]}
    與${logininfo.username}達到了同樣的效果。
    “[]”引用方式的意義在于,如果屬性名中出現了特殊字符,如“.”或者“-”,
    此時就必須使用“[]”獲取屬性值以避免語法上的沖突(系統開發時應盡量避免
    這一現象的出現)。
    與之等同的JSP Script大致如下:
    LoginInfo logininfo =
    (LoginInfo)session.getAttribute(“logininfo”);
    String username = logininfo.getUsername();
    可以看到,EL大大節省了編碼量。
    這里引出的另外一個問題就是,EL 將從哪里找到logininfo 對象,對于
    ${logininfo.username}這樣的表達式而言,首先會從當前頁面中尋找之前是
    否定義了變量logininfo,如果沒有找到則依次到Request、Session、
    Application 范圍內尋找,直到找到為止。如果直到最后依然沒有找到匹配的
    變量,則返回null.
    如果我們需要指定變量的尋找范圍,可以在EL表達式中指定搜尋范圍:
    ${pageScope.logininfo.username}
    ${requestScope.logininfo.username}
    ${sessionScope.logininfo.username}
    ${applicationScope.logininfo.username}
    在Spring 中,所有邏輯處理單元返回的結果數據,都將作為Attribute 被放
    置到HttpServletRequest 對象中返回(具體實現可參見Spring 源碼中
    org.springframework.web.servlet.view.InternalResourceView.
    exposeModelAsRequestAttributes方法的實現代碼),也就是說Spring
    MVC 中,結果數據對象默認都是requestScope。因此,在Spring MVC 中,
    以下尋址方法應慎用:
    ${sessionScope.logininfo.username}
    ${applicationScope.logininfo.username}
    Ø ${1+2}
    結果為表達式計算結果,即整數值3。
    Ø ${i>1}
    如果變量值i>1的話,將返回bool類型true。與上例比較,可以發現EL會自
    動根據表達式計算結果返回不同的數據類型。
    表達式的寫法與java代碼中的表達式編寫方式大致相同。

    IF / CHOOSE:

    <c:if test="${var.index % 2 == 0}">
    *
    </c:if>
    判定條件一般為一個EL表達式。
    <c:if>并沒有提供else子句,使用的時候可能有些不便,此時我們可以通過<c:choose>
    tag來達到類似的目的:
    <c:choose>
    <c:when test="${var.index % 2 == 0}">
    *
    </c:when>
    <c:otherwise>
    !
    </c:otherwise>
    </c:choose>
    類似Java 中的switch 語句,<c:choose>提供了復雜判定條件下的簡化處理手法。其
    中<c:when>子句類似case子句,可以出現多次。上面的代碼,在奇數行時輸出“*”號,
    而偶數行時輸出“!”。
    ---------------------------------------------

    再補充:

     1    EL表達式用${}表示,可用在所有的HTML和JSP標簽中 作用是代替JSP頁面中復雜的JAVA代碼.

            2   EL表達式可操作常量 變量 和隱式對象. 最常用的 隱式對象有${param}和${paramValues}. ${param}表示返回請求參數中單個字符串的值. ${paramValues}表示返回請求參數的一組值.pageScope表示頁面范圍的變量.requestScope表示請求對象的變量. sessionScope表示會話范圍內的變量.applicationScope表示應用范圍的變量.

            3   <%@  page isELIgnored="true"%> 表示是否禁用EL語言,TRUE表示禁止.FALSE表示不禁止.JSP2.0中默認的啟用EL語言.

            4   EL語言可顯示 邏輯表達式如${true and false}結果是false    關系表達式如${5>6} 結果是false     算術表達式如 ${5+5} 結果是10

            5   EL中的變量搜索范圍是:page request session application   點運算符(.)和"[ ]"都是表示獲取變量的值.區別是[ ]可以顯示非詞類的變量


    本文來自CSDN博客,轉載請標明出處:http://blog.csdn.net/stonec/archive/2009/10/09/4647394.aspx

    posted @ 2009-11-23 10:53 jimphei 閱讀(282) | 評論 (0)編輯 收藏

     sitemesh應用Decorator模式,用filter截取request和response,把頁面組件head,content,banner結合為一個完整的視圖。通常我們都是用include標簽在每個jsp頁面中來不斷的包含各種header, stylesheet, scripts and footer,現在,在sitemesh的幫助下,我們可以開心的刪掉他們了。如下圖,你想輕松的達到復合視圖模式,那末看完本文吧。

    一、在WEB-INF/web.xml中copy以下filter的定義:

    <?xml version="1.0" encoding="GBK"?>
    <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">

    <filter>
      <filter-name>sitemesh</filter-name>
         <filter-class>com.opensymphony.module.sitemesh.filter.PageFilter</filter-class>
      </filter>

      <filter-mapping>
         <filter-name>sitemesh</filter-name>
         <url-pattern>/*</url-pattern>
      </filter-mapping>

    </web-app>

    二、copy所需sitemesh-2.3.jar到WEB-INF\lib下。(這里可以下載http://www.opensymphony.com/sitemesh/)

    三、
    建立WEB-INF/decorators.xml描述各裝飾器頁面。

    <decorators defaultdir="/decorators">
                                   <decorator name="main" page="main.jsp">
                                       <pattern>*</pattern>
                                   </decorator>
                            </decorators>

      上面配置文件指定了裝飾器頁面所在的路徑,并指定了一個名為main的裝飾器,該裝飾器默認裝飾web應用根路徑下的所有頁面。

    四、
    建立裝飾器頁面 /decorators/main.jsp

  • <%@ page contentType="text/html; charset=GBK"%>
    <%@ taglib uri="http://www.opensymphony.com/sitemesh/decorator" prefix="decorator"%> <html>
          <head>
              <title><decorator:title default="裝飾器頁面..." /></title>
              <decorator:head />
          </head>
         <body>
            sitemesh的例子<hr>
            <decorator:body />
            <hr>chen56@msn.com
        </body>
    </html>
     

    五、建立一個的被裝飾頁面 /index.jsp(內容頁面)

  • <%@ page contentType="text/html; charset=GBK"%>
                            <html>
                                 <head>
                                   <title>Agent Test</title>
                                 </head>
                                 <body>
                                   <p>本頁只有一句,就是本句.</p>
                                 </body>
                            </html>

      最后訪問index.jsp,將生成如下頁面:

          而且,所有的頁面也會如同index.jsp一樣,被sitemesh的filter使用裝飾模式修改成如上圖般模樣,卻不用再使用include標簽。



    1. 裝飾器     decorator概念
          為了建立可復用的web應用程序,一個通用的方法是建立一個分層系統,如同下面一個普通的web應用:
      • 前端:JSP和Servlets,或jakarta的velocity 。。。
      • 控制層框架 Controller : (Struts/Webwork)
      • 業務邏輯 Business :主要業務邏輯
      • 持久化框架 :hibernate/jdo

          可糟糕的是前端的頁面邏輯很難被復用,當你在每一個頁面中用數之不盡的include來復用公共的header, stylesheet, scripts,footer時,一個問題出現了-重復的代碼,每個頁面必須用copy來復用頁面結構,而當你需要創意性的改變頁面結構時,災難就愛上了你。

           sitemesh通過filter截取request和response,并給原始的頁面加入一定的裝飾(可能為header,footer...),然后把結果返回給客戶端,并且被裝飾的原始頁面并不知道sitemesh的裝飾,這也就達到了脫耦的目的。

           據說即將新出臺的Portlet規范會幫助我們標準的實現比這些更多更cool的想法,但可憐的我還不懂它到底是一個什末東東,有興趣的人可以研究
      jetspeed,或JSR (Java Specification Request) 168,但我想sitemesh如此簡單,我們不妨先用著。

       

      讓我們看看怎樣配置環境
          除了要copy到WEB-INF/lib中的sitemesh.jar外,還有2個文件要建立到WEB-INF/:
      • sitemesh.xml (可選)  
      • decorators.xml

      sitemesh.xml 可以設置2種信息:

      Page Parsers :負責讀取stream的數據到一個Page對象中以被SiteMesh解析和操作。(不太常用,默認即可)

      Decorator Mappers : 不同的裝飾器種類,我發現2種比較有用都列在下面。一種通用的mapper,可以指定裝飾器的配置文件名,另一種可打印的裝飾器,可以允許你當用http://localhost/aaa/a.html?printable=true方式訪問時給出原始頁面以供打印(免得把header,footer等的花哨的圖片也搭上)

      (但一般不用建立它,默認設置足夠了:com/opensymphony/module/sitemesh/factory/sitemesh-default.xml):

      范例:

      <sitemesh>
           <page-parsers>
             <parser default="true" class="com.opensymphony.module.sitemesh.parser.DefaultPageParser" />
             <parser content-type="text/html" class="com.opensymphony.module.sitemesh.parser.FastPageParser" />
             <parser content-type="text/html;charset=ISO-8859-1" class="com.opensymphony.module.sitemesh.parser.FastPageParser" />
           </page-parsers>

           <decorator-mappers>
             <mapper class="com.opensymphony.module.sitemesh.mapper.ConfigDecoratorMapper">
               <param name="config" value="/WEB-INF/decorators.xml" />
             </mapper>
               <mapper class="com.opensymphony.module.sitemesh.mapper.PrintableDecoratorMapper">
                  <param name="decorator" value="printable" />
                  <param name="parameter.name" value="printable" />
                          <param name="parameter.value" value="true" />
               </mapper>
        
      </decorator-mappers>
      </sitemesh>

      decorators.xml :定義構成復合視圖的所有頁面構件的描述(主要結構頁面,header,footer...),如下例:

      <decorators defaultdir="/decorators">
           <decorator name="main" page="main.jsp">
             <pattern>*</pattern>
           </decorator>
           <decorator name="printable" page="printable.jsp" role="customer" webapp="aaa" />
      </decorators>
      • defaultdir: 包含裝飾器頁面的目錄
      • page : 頁面文件名
      • name : 別名
      • role : 角色,用于安全
      • webapp : 可以另外指定此文件存放目錄
      • Patterns : 匹配的路徑,可以用*,那些被訪問的頁面需要被裝飾。

       

      最重要的是寫出裝飾器本身(也就是那些要復用頁面,和結構頁面)。
          其實,重要的工作就是制作裝飾器頁面本身(也就是包含結構和規則的頁面),然后把他們描述到decorators.xml中。

          讓我們來先看一看最簡單的用法:其實最常用也最簡單的用法就是我們的hello例子,面對如此眾多的技術,我想只要達到功能點到為止即可,沒必要去研究太深(除非您有更深的需求)。

      <%@ page contentType="text/html; charset=GBK"%>
                                  <%@ taglib uri="http://www.opensymphony.com/sitemesh/decorator" prefix="decorator" %>
                                  <html>
                                       <head>
                                         <title><decorator:title default="裝飾器頁面..." /></title>
                                         <decorator:head />
                                       </head>
                                       <body>
                                         sitemesh的例子<hr>
                                         <decorator:body />
                                         <hr>chen56@msn.com
                                       </body>
                                  </html>
                                  

      我們在裝飾器頁面只用了2個標簽:

      <decorator:title default="裝飾器頁面..." />       : 把請求的原始頁面的title內容插入到<title></title>中間。

      <decorator:body /> : 把請求的原始頁面的body內的全部內容插入到相應位置。

      然后我們在decorator.xml中加入以下描述即可:

      <decorator name="main" page="main.jsp">
             <pattern>*</pattern>
      </decorator>

      這樣,請求的所有頁面都會被重新處理,并按照main.jsp的格式重新展現在你面前。

       

      讓我們看看更多的用法。(抄襲sitemesh文檔)
      以下列著全部標簽:
      Decorator Tags Page Tags
      被用于建立裝飾器頁面. 被用于從原始內容頁面訪問裝飾器.
      <decorator:head />
      <decorator:body />
      <decorator:title />
      <decorator:getProperty />
      <decorator:usePage />
      <page:applyDecorator />
      <page:param
       

      <decorator:head />

      插入原始頁面(被包裝頁面)的head標簽中的內容(不包括head標簽本身)。

      <decorator:body />

      插入原始頁面(被包裝頁面)的body標簽中的內容。

      <decorator:title [ default="..." ] />

      插入原始頁面(被包裝頁面)的title標簽中的內容,還可以添加一個缺省值。

      例:

      /decorator/main.jsp中 (裝飾器頁面): <title><decorator:title default="卻省title-hello"     /> - 附加標題</title>

      /aaa.jsp中 (原始頁面):<title>aaa頁面</title>

      訪問/aaa.jsp的結果:<title>aaa頁面 - 附加標題</title>

      <decorator:getProperty property="..." [ default="..." ] [ writeEntireProperty="..." ]/>

      在標簽處插入原始頁面(被包裝頁面)的原有的標簽的屬性中的內容,還可以添加一個缺省值。

      sitemesh文檔中的例子很好理解:
      The decorator: <body bgcolor="white"<decorator:getProperty property="body.onload" writeEntireProperty="true" />>
      The undecorated page: <body onload="document.someform.somefield.focus();">
      The decorated page: <body bgcolor="white" onload="document.someform.somefield.focus();">

      注意,writeEntireProperty="true"會在插入內容前加入一個空格。

      <decorator:usePage id="..." />
      象jsp頁面中的<jsp:useBean>標簽一樣,可以使用被包裝為一個Page對象的頁面。 (懶的用)

      例:可用<decorator:usePage id="page" /><%=page.getTitle()%>達到<decorator:title/>的訪問結果。

      <page:applyDecorator name="..." [ page="..." title="..." ] >
      <page:param name="..."> ... </page:param>
      <page:param name="..."> ... </page:param>
      </page:applyDecorator>

      應用包裝器到指定的頁面上,一般用于被包裝頁面中主動應用包裝器。這個標簽有點不好理解,我們來看一個例子:

      包裝器頁面 /decorators/panel.jsp:<p><decorator:title /></p>     ... <p><decorator:body /></p>
           并且在decorators.xml中有<decorator name="panel" page="panel.jsp"/>

      一個公共頁面,即將被panel包裝:/public/date.jsp:  
           ... <%=new java.util.Date()%>     ...<decorator:getProperty property="myEmail" />

      被包裝頁面 /page.jsp :
           <title>page的應用</title>
           .....  

           <page:applyDecorator name="panel" page="/_public/date.jsp" >
             <page:param name="myEmail"> chen_p@neusoft.com </page:param>
           </page:applyDecorator>

      最后會是什末結果呢?除了/page.jsp會被默認的包裝頁面包裝上header,footer外,page.jsp頁面中還內嵌了date.jsp頁面,并且此date.jsp頁面還會被panel.jsp包裝為一個title加body的有2段的頁面,第1段是date.jsp的title,第2段是date.jsp的body內容。

      另外,page:applyDecorator中包含的page:param標簽所聲明的屬性值還可以在包裝頁面中用decorator:getProperty標簽訪問到。


      可打印的界面裝飾
           前面說過有1種可打印的裝飾器,可以允許你當用http://localhost/aaa/a.html?printable=true方式訪問時,應用其他的裝飾器(自己指定),給出原始頁面以供打印(免得把header,footer等的花哨的圖片也搭上)。

      讓我們來看一看怎樣實現他:

      1.首先在WEB-INFO/sitemesh.xml中設置:
           <mapper class="com.opensymphony.module.sitemesh.mapper.PrintableDecoratorMapper">
             <param name="decorator" value="printable" />
             <param name="parameter.name" value="printable" />
             <param name="parameter.value" value="true" />
           </mapper>
      這樣就可以通過?printable=true來使用名為printable的裝飾器,而不是用原來的裝飾器。

      2.在WEB-INFO/decorators.xml中定義相應的printable裝飾器
           <decorator name="printable" page="printable.jsp"/>

      3.最后編寫printable裝飾器/decorators/printable.jsp

      <%@ taglib uri="sitemesh-decorator" prefix="decorator" %>
      <html>
      <head>
           <title><decorator:title /></title>
           <decorator:head />
      </head>
      <body>

           <h1><decorator:title /></h1>
           <p align="right"><i>(printable version)</i></p>

           <decorator:body />

      </body>
      </html>

      這樣就可以讓一個原始頁面通過?printable=true開關來切換不同的裝飾器頁面。

       

      中文問題
      由于sitemesh內部所使用的缺省字符集為iso-8859-1,直接使用會產生亂碼,我們可以通過以下方法糾正之:
      • 方法1:可以在您所用的application server的配置文件中找一找,有沒有設置encoding或charset的項目,然后設成gbk或gb2312即可
      • 方法2:這也是我們一直使用的方法。
        1.在每一個jsp頁里設置: <%@ page contentType="text/html; charset=gbk"%> 來告訴server你所要求的字符集。
        2.在每個jsp頁的head中定義:<META HTTP-EQUIV="content-type" CONTENT="text/html; charset=gbk"> 來告訴瀏覽器你所用的字符集。
      總結:使用sitemesh最通常的途徑:

      1.配置好環境,

      2.在WEB-INFO/decroators.xml中描述你將建立的包裝器。

      3.開發在decroators.xml中描述的包裝器,最好存放在/_decorators目錄下

      4.ok ,可以看看辛勤的成果了 :)

      posted @ 2009-11-22 09:55 jimphei 閱讀(194) | 評論 (0)編輯 收藏

      主站蜘蛛池模板: 丁香花在线视频观看免费| 亚洲成av人在片观看| 中文字幕视频在线免费观看| 亚洲中文字幕久久精品蜜桃| 香蕉视频在线观看亚洲| 亚洲av片一区二区三区| 久久久久国产精品免费免费搜索| 成人片黄网站色大片免费观看APP| 亚洲AV永久无码精品网站在线观看 | 国产男女猛烈无遮档免费视频网站 | 亚洲av区一区二区三| 啦啦啦在线免费视频| 久草视频免费在线| 久久久久国产精品免费看| 一级做a毛片免费视频| 国产亚洲精品2021自在线| 四虎亚洲精品高清在线观看| 亚洲黄色片在线观看| 亚洲AV成人片色在线观看| 亚洲日本乱码在线观看| 亚洲成a人片在线观看老师| 免费看的黄色大片| 人禽杂交18禁网站免费| 2015日韩永久免费视频播放| 日韩成人免费视频| 国产精品免费久久久久电影网| 美女露隐私全部免费直播| 亚洲AV无码专区国产乱码不卡| 亚洲娇小性xxxx色| 伊人久久亚洲综合影院首页| 亚洲人成www在线播放| 2020天堂在线亚洲精品专区| 亚洲国产日韩在线一区| 亚洲视频国产精品| 亚洲国产夜色在线观看| 国产精品亚洲精品青青青| 亚洲AV无码一区二区三区人 | 99久在线国内在线播放免费观看 | 亚洲成a人片毛片在线| 亚洲男女一区二区三区| 香蕉大伊亚洲人在线观看|