SIteMesh介绍

一、SIteMesh介绍

一、SiteMesh简介
SiteMesh是由一个基于Web页面布局、装饰以及与现存Web应用整合的框架。它能帮助我们在由大量页面构成的项目中创建一致的页面布局和外观,如一致的导航条,一致的banner,一致的版权,等等。 它不仅仅能处理动态的内容,如jsp,PHP,asp等产生的内容,它也能处理静态的内容,如htm的内容,使得它的内容也符合你的页面结构的要求。甚至于它能将HTML文件象include那样将该文件作为一个面板的形式嵌入到别的文件中去。所有的这些,都是GOF的Decorator模式的最生动的实现。尽管它是由java语言来实现的,但它能与其他Web应用很好地集成。与传统区别如下图:
二、SiteMesh原理
SiteMesh框架是OpenSymphony团队开发的一个非常优秀的页面装饰器框架,它通过对用户请求进行过滤,并对服务器向客户端响应也进行过滤,然后给原始页面加入一定的装饰(header,footer等),然后把结果返回给客户端。通过SiteMesh的页面装饰,可以提供更好的代码复用,所有的页面装饰效果耦合在目标页面中,无需再使用include指令来包含装饰效果,目标页与装饰页完全分离,如果所有页面使用相同的装饰器,可以是整个Web应用具有统一的风格。

三、SiteMesh简单例子
接下来通过一个SiteMesh简单例子来了解SiteMesh的功能

  • 将sitemesh-2.3.jar放 到 [web-app]/WEB-INF/lib目录下;
  • 在[web-app]/WEB-INF/新建一个decorators.xml文件,包含以下内容
    1. <?xmlversion="1.0"encoding="utf-8"?>
    2. <decoratorsdefaultdir="/decorators">
    3. <!--此处用来定义不需要过滤的页面-->
    4. <excludes>
    5. </excludes>
    6. <!--用来定义装饰器要过滤的页面-->
    7. <decoratorname="main"page="main.jsp"<pattern>/*</pattern>
    8. </decorator>
    9. </decorators>
    Xml代码
    1. <?xmlversion="1.0"encoding="utf-8"?>
    2. <decoratorsdefaultdir="/decorators">
    3. <!--此处用来定义不需要过滤的页面-->
    4. excludes</
    5. <!--用来定义装饰器要过滤的页面-->
    6. decoratorname="main"page="main.jsp"pattern>/*decoratordecorators>
  • 在[web-app]/WEB-INF/web.xml添加以下内容<filter>
  • <filter-name>sitemesh</filter-name>
  • <filter-class>
  • com.opensymphony.module.sitemesh.filter.PageFilter
  • </filter-class>
  • </filter>
  • <filter-mapping>
  • </filter-name>
  • <url-pattern>/*</url-pattern>
  • </filter-mapping>
filterfilter-name>sitemeshfilter-class com.opensymphony.module.sitemesh.filter.PageFilter
  • filter-mappingurl-pattern>
  • 在[web-app]下创建一个decorators文件夹,在该文件下再创建一个装饰页面main.jsp,包含以下内容<%@pagelanguage="java"contentType="text/html;charset=utf-8"
  • pageEncoding="utf-8"% <%@tagliburi="http://www.opensymphony.com/sitemesh/decorator"prefix="decorator"%>
  • <!DOCTYPEhtmlPUBLIC"-//W3C//DTDHTML4.01Transitional//EN""http://www.w3.org/TR/html4/loose.dtd"<html>
  • <!--第一个装饰页面-->
  • <head>
  • <!--从被装饰页面获取title标签内容,并设置认值-->
  • <title><decorator:titledefault="认title"/></title>
  • <!--从被装饰页面获取head标签内容-->
  • <decorator:head/>
  • </head>
  • <body>
  • <h2>SiteMesh装饰header</h2>
  • <hr/>
  • <!--从被装饰页面获取body标签内容-->
  • <decorator:body/>
  • <h2>SiteMesh装饰footer</h2>
  • </body>
  • </html>
  • 在[web-app]下创建被装饰页面index.jsp,包含以下内容:<html>
  • <!--第一个被装饰(目标)页面-->
  • <head>
  • <metahttp-equiv="Content-Type"content="text/html;charset=utf-8"<title>被装饰(目标)页面title</title>
  • </head>
  • <body>
  • <h4>被装饰(目标)页面body标签内内容。</h4>
  • <h3>使用SiteMesh的好处?</h3>
  • <ul>
  • <li>被装饰(目标)页面和装饰页面完全分离。</li>
  • <li>做到真正的页面复用,一个装饰页面装饰多个被装饰(目标)页面。</li>
  • <li>更容易实现统一的网站风格。<li>还有。。。</ul>
  • </body>
  • <!--第一个被装饰(目标)页面-->
  • metahttp-equiv="Content-Type"content="text/html;charset=utf-8">被装饰(目标)页面titleh4>被装饰(目标)页面body标签内内容。h3>使用SiteMesh的好处?ulli>被装饰(目标)页面和装饰页面完全分离。>做到真正的页面复用,一个装饰页面装饰多个被装饰(目标)页面。>更容易实现统一的网站风格。>还有。。。>
  • 运行结果如下图:


  • 四、总结
    从以上的例子,可以看出通过SiteMesh装饰,不需要在每个目标页面中将header和footer等共同文件include进去,被装饰(目标)页面和装饰页面完全分离。本文只对SiteMesh做一个简单的介绍,SiteMesh可以Velocity,FreeMarker等开源模板工具结合使用,降低页面开发复杂度。
    本文例子工程SiteMeshDemoL1代码下载:
    SiteMeshDemoL1.rar(153.96 KB)
    SiteMeshDemoL1.rar(153.96 KB)

    相关文章

    php输出xml格式字符串
    J2ME Mobile 3D入门教程系列文章之一
    XML轻松学习手册
    XML入门的常见问题(一)
    XML入门的常见问题(三)
    XML轻松学习手册(2)XML概念