`
zz563143188
  • 浏览: 2277034 次
  • 性别: Icon_minigender_1
  • 来自: 珠海
博客专栏
77fc734c-2f95-3224-beca-6b8da12debc8
编程工具介绍
浏览量:579128
D9710da2-8a00-3ae6-a084-547a11afab81
Spring Mvc实战(...
浏览量:1088321
D3f88135-07de-3968-a0f0-d2f13428c267
项目开发经验
浏览量:1658201
社区版块
存档分类
最新评论

SiteMesh小例子及详细介绍

阅读更多

企业级项目实战(带源码)地址http://zz563143188.iteye.com/blog/1825168

收集五年的开发资料下载地址:  http://pan.baidu.com/share/home?uk=4076915866&view=share

 

一、SiteMesh项目简介 

      OS(OpenSymphony)的SiteMesh是一个用来在JSP中实现页面布局和装饰(layout and decoration) 
的框架组件,能够帮助网站开发人员较容易实现页面中动态内容和静态装饰外观的分离。 

       Sitemesh是由一个基于Web页面布局、装饰以及与现存Web应用整合的框架。它能帮助我们在由大 
量页面构成的项目中创建一致的页面布局和外观,如一致的导航条,一致的banner,一致的版权,等等。 
它不仅仅能处理动态的内容,如jsp,php,asp等产生的内容,它也能处理静态的内容,如htm的内容, 
使得它的内容也符合你的页面结构的要求。甚至于它能将HTML文件象include那样将该文件作为一个面板 
的形式嵌入到别的文件中去。所有的这些,都是GOF的Decorator模式的最生动的实现。尽管它是由java语言来实现的,但它能与其他Web应用很好地集成。 

       官方:http://www.opensymphony.com/sitemesh/ 

       下载地址:http://www.opensymphony.com/sitemesh/download.action 目前的最新版本是Version 2.3; 

二、为什么要使用SiteMesh? 

    我们的团队开发J2EE应用的时候,经常会碰到一个比较头疼的问题: 

         由于Web页面是由不同的人所开发,所以开发出来的界面通常是千奇百怪,通常让项目管理人员苦笑不得。 

     而实际上,任何一个项目都会要求界面的统一风格和美观,既然风格统一,那就说明UI层肯定有很多可以抽出来 
共用的静态或动态部分;如何整合这些通用的静态或动态UI呢?Apache Tiles框架站了出来很好的解决了这一问题, 
再加上他与struts的完美集成,导致大小项目都把他作为UI层的首选框架, 

但是: 

   Tiles确实有着它很多的不足之处,下文我会介绍,本文想说的是,除了Apache Tiles框架,其实我们还有更好的解 
决方案,那就是:SiteMesh; 

本文 
   
   介绍了一个基于Web页面的布局、装饰以及应用整合的框架Sitemesh,它能帮助你为你的应用创建一致的外观, 
很好的取代Apache Tiles; 

三、SiteMesh VS Apache Tiles 

     用过struts的朋友应该对Apache Tiles的不会陌生,我曾经有一篇文章介绍过struts中tiles框架的组合与继承, 
现在怎么看怎么觉得复杂; 
      
       从使用角度来看,Tiles似乎是Sitemesh标签<page:applyDecorator>的一个翻版。其实sitemesh最强的 
一个特性是sitemesh将decorator模式用在过滤器上。任何需要被装饰的页面都不知道它要被谁装饰,所以它就 
可以用来装璜来自php、asp、CGI等产生的页面了。你可以定义若干个装饰器,根据参数动态地选择装饰器, 
产生动态的外观以满足你的需求。它也有一套功能强大的属性体系,它能帮助你构建功能强大而灵活的装饰器。 
相比较而言,在这方面Tiles就逊色许多。 

       个人觉得在团队开发里面,Apache Tiles框架会导致所有人不仅仅要了解并且清楚Apache Tiles的存在, 
并且要特别熟悉每一个Tiles layout模板的作用,否则就可能出现用错模板的情况;除此之外,每个人涉及到 
的所有WEB页面都需要去配置文件里面逐个配置,不仅麻烦出错的几率还高; 
       而以上所有的不足都是SiteMesh所不存在的; 


四、SiteMesh的基本原理 

      一个请求到服务器后,如果该请求需要sitemesh装饰,服务器先解释被请求的资源,然后根据配置文件 
获得用于该请求的装饰器,最后用装饰器装饰被请求资源,将结果一同返回给客户端浏览器。 

五、如何使用SiteMesh 

   这里以struts2+spring2+hibernate3构架的系统为例 
     1、下载SiteMesh 
          下载地址:http://www.opensymphony.com/sitemesh/download.action 目前的最新版本是Version 2.3; 
      
        2、在工程中引入SiteMesh的必要jar包,和struts2-sitemesh-plugin-2.0.8.jar; 
      
       3、修改你的web.xml,在里面加入sitemesh的过滤器,示例代码如下: 
         
<!-- sitemesh配置 --> 
    <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> 
      

         注意过滤器的位置:应该在struts2的org.apache.struts2.dispatcher.FilterDispatcher过滤器之前org.apache.struts2.dispatcher.ActionContextCleanUp过滤器之后,否则会有问题; 

       4、在下载的SiteMesh包中找到sitemesh.xml,(/sitemesh-2.3/src/example-webapp/WEB-INF目录下就有) 

         将其拷贝到/WEB-INF目录下; 

       5、在sitemesh.xml文件中有一个property结点(如下),该结点指定了decorators.xml在工程中的位置,让sitemesh.xml能找到他; 
按照此路径新建decorators.xml文件,当然这个路径你可以任意改变,只要property结点的value值与其匹配就行; 


<property name="decorators-file" value="/WEB-INF/sitemesh/decorators.xml"/> 


    
      6、在WebRoot目录下新建decorators目录,并在该目录下新建一个模板jsp,根据具体项目风格编辑该模板, 
如下示例:我的模板:main.jsp 

<%@ page language="java" pageEncoding="UTF-8"%> 
<%@taglib prefix="decorator" 
     uri="http://www.opensymphony.com/sitemesh/decorator"%> 
<%@taglib prefix="page" uri="http://www.opensymphony.com/sitemesh/page"%> 
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1 Transitional//EN" 
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> 
<% 
     response.setHeader("Pragma", "no-cache"); 
     response.setHeader("Cache-Control", "no-cache"); 
     response.setDateHeader("Expires", 0); 
%> 
<html> 
    <head> 
        <title><decorator:title default="kangxm test" /> 
        </title> 
        <!-- 页面Head由引用模板的子页面来替换 --> 
        <decorator:head /> 
    </head> 
    <body id="page-home"> 
        <div id="page-total"> 
            <div id="page-header"> 
                <table width="100%" border="0" cellspacing="0" cellpadding="0"> 
                    <tr> 
                        <td> 
                            <div class="topFunc"> 
                                 我的账户 
                                 | 
                                 退出 
                            </div> 
                        </td> 
                    </tr> 
                </table> 
            </div> 
        </div> 
        <!-- end header --> 
        <!--   Menu Tag begin --> 
        <div id="page-menu" style="margin-top: 8px; margin-bottom: 8px;"> 
            <div> 
                 这里放菜单 
            </div> 
        </div> 
        <!--   Menu Tag end --> 
        <div id="page-content" class="clearfix"> 
            <center> 
                <table width="100%" border="0" cellpadding="0" cellspacing="0"> 
                    <tr> 
                        <td> 
                            <decorator:body /><!-- 这里的内容由引用模板的子页面来替换 --> 
                        </td> 
                    </tr> 
                </table> 
            </center> 
        </div> 
        <!-- end content --> 
        <div id="page-footer" class="clearfix"> 

             这里放页面底部 
            <!-- end footer --> 
        </div> 
        <!-- end page --> 
    </body> 
</html> 


这就是个简单的模板,页面的头和脚都由模板里的静态HTML决定了,主页面区域用的是<decorator:body />标签; 
也就是说凡是能进入过滤器的请求生成的页面都会默认加上模板上的头和脚,然后页面自身的内容将自动放到<decorator:body />标签所在位置; 

<decorator:title default="Welcome to test sitemesh!" />:读取被装饰页面的标题,并给出了默认标题。 
<decorator:head />:读取被装饰页面的<head>中的内容; 
<decorator:body />:读取被装饰页面的<body>中的内容; 

      7、说到这里大家就要想了,那如果某个特殊的需求请求路径在过滤器的范围内,但又不想使用模板怎么办? 
你总不能这么不讲道理吧! 
         大家放心吧,SiteMesh早就考虑到这一点了,上面第5步说道的decorators.xml这个时候就起到作用了! 
        
下面是我的decorators.xml: 

<?xml version="1.0" encoding="ISO-8859-1"?> 
<decorators defaultdir="/decorators"> 
    <!-- Any urls that are excluded will never be decorated by Sitemesh --> 
    <excludes> 
        <pattern>/index.jsp*</pattern> 
          <pattern>/login/*</pattern> 
    </excludes> 
    <decorator name="main" page="main.jsp"> 
        <pattern>/*</pattern> 
    </decorator> 
</decorators> 

decorators.xml有两个主要的结点: 
       decorator结点指定了模板的位置和文件名,通过pattern来指定哪些路径引用哪个模板 
       excludes结点则指定了哪些路径的请求不使用任何模板 

如上面代码,/index.jsp和凡是以/login/开头的请求路径一律不使用模板; 

另外还有一点要注意的是:decorators结点的defaultdir属性指定了模板文件存放的目录; 

六、实战感受 

      刚刚做完一个用到sitemesh的项目,跟以前用tiles框架相比,最大的感受就是简单,系统设计阶段 
就把模板文件和sitemesh框架搭好了!哪些页面使用框架哪些不使用,全部都通过UI Demo很快就定义出来了; 
在接下来的开发中所有成员几乎感受不到sitemesh的存在,各自仅仅关心自己的模块功能实现; 

七、总结 

    使用sitemesh给我们带来的是不仅仅是页面结构问题,它的出现让我们有更多的时间去关注底层业务 
逻辑,而不是整个页面的风格和结构。它让我们摆脱了大量用include方式复用页面尴尬局面,也避免了tiles 
框架在团队开发中的复杂度,它还提供了很大的灵活性以及给我们提供了整合异构Web系统页面的一种方案

分享到:
评论

相关推荐

    sitemesh使用例子

    sitemesh 使用例子。 &lt;?xml version="1.0" encoding="utf-8"?&gt; &lt;decorators defaultdir="/decorators"&gt; &lt;!-- 此处用来定义不需要过滤的页面 --&gt; &lt;excludes&gt; &lt;/excludes&gt; &lt;!-- 用来定义装饰器要过滤的...

    freemarker 与sitemesh 整合例子

    Freemarker和Sitemesh是两个在Web开发中常用的开源技术。Freemarker是一个模板引擎,主要用于生成动态HTML或其他文本格式的输出,而Sitemesh则是一个页面布局和装饰框架,用于统一网站的外观和感觉。这两者的整合...

    sitemesh框架简单例子

    在“sitemesh框架简单例子”这个教程中,我们将深入理解Sitemesh的基本概念和用法。 首先,我们需要了解Sitemesh的工作原理。Sitemesh通过拦截HTTP请求,对返回的HTML内容进行装饰。它使用一种叫做装饰器...

    sitemesh 例子

    此外,提供的"简单文档说明"可能详细介绍了如何设置和运行这个例子,包括安装Sitemesh库、配置Web应用、创建装饰器和测试页面等步骤。阅读这份文档可以帮助初学者快速上手。 总的来说,Sitemesh是一个强大的工具,...

    SpringMVC-Freemarker_Sitemesh3例子

    **SpringMVC、Freemarker与Sitemesh3详解*...通过这个例子,我们可以深入理解SpringMVC、Freemarker和Sitemesh3如何协同工作,构建出具有统一布局、易于维护的Web应用。这有助于提升开发效率,同时提供一致的用户体验。

    sitemesh例子

    在“sitemesh例子”中,我们将探讨如何使用 Sitemesh 来实现这一目标。 **安装与配置 Sitemesh** 1. **下载 Sitemesh**:首先从官方仓库或者 Maven 仓库下载 Sitemesh 的 JAR 包,将其添加到项目的类路径中。 2. *...

    Struts2.0 与 sitemesh的例子

    Struts2.0 与 sitemesh的例子 博文链接:https://jiangyou001.iteye.com/blog/183698

    siteMesh demo 例子

    入门的demo...siteMesh与freemarker结合。。 siteMesh与velocity结合。。并且在siteMesh.xml用了不同的装饰器。。每个装饰器都有注释。。可以帮助理解。。请看readme.txt

    SiteMesh教程及SiteMesh官方文档翻译

    ### SiteMesh教程及SiteMesh官方文档翻译 #### 使用SiteMesh简化网页布局 SiteMesh是一款用于Web应用程序中的页面布局和装饰的框架。它采用Decorator模式,通过过滤器(filter)拦截请求和响应,将不同的页面组件...

    sitemesh的使用和例子

    **Sitemesh** 是一个开源的网页布局和装饰框架,主要用在Java Web应用程序中,用于提供统一的页面布局和美化。它可以帮助开发者快速创建整洁、一致的网站外观,通过分离内容、样式和布局,使得代码更加模块化,易于...

    struts2+sitemesh例子

    Struts2和Sitemesh是两个非常流行的Java Web开发框架,它们在构建高效、结构化的MVC(模型-视图-控制器)应用中起到关键作用。Struts2是一个基于MVC设计模式的开源框架,主要用于控制应用程序的流程,而Sitemesh则是...

    springmvc + mybatis + sitemesh3 超简洁例子

    springmvc + mybatis + sitemesh3 超简洁例子 整合springmvc mybatis 方法请看: http://blog.csdn.net/kokoyuo/article/details/52808510

    springmvc + mybatis + sitemesh3登陆 超简洁例子mysql

    这个例子为初学者提供了一个了解Spring MVC、MyBatis和Sitemesh3集成的起点,同时也展示了如何实现基本的用户登录功能。通过学习和实践这个项目,开发者可以更好地理解这些技术的协同工作方式,为进一步的Web开发...

    siteMesh例子

    SiteMesh简介: SiteMesh是一个Web页面布局修饰框架, 用于构建包含大量页面, 需要一致的外观样式(look/fell), 导航和布局机制的大型网站. SiteMesh应用Decorator模式,用filter截取request和response,把页面组件...

    sitemesh入门demo

    以下是关于Sitemesh的详细讲解: 1. **安装与配置** - 首先,你需要将Sitemesh的JAR文件添加到你的项目类路径中。这可以通过Maven或Gradle的依赖管理来实现。 - 接着,在Web应用的`web.xml`配置文件中,需要配置...

    ssh2(事务,AOP,IoC即DI)+EhCache+oscache+proxool+MySQL+SiteMesh+Gzip例子

    jQuery+json+struts2+spring3(事务,AOP,IoC即DI)+hibernte3+EhCache+oscache+proxool+MySQL+SiteMesh+Gzip lj例子

    Sitemesh例子分享

    通过学习和运行这个例子,你可以更好地理解Sitemesh的工作原理和实际应用。 总之,Sitemesh是一个强大的工具,可以帮助开发者构建整洁、一致的网站界面。通过理解和掌握Sitemesh,你可以提高Web应用的用户体验,并...

    springmvc + mybatis + sitemesh3 简洁例子

    springmvc + mybatis + sitemesh3 简洁例子 springmvc + mybatis 整合过程: http://blog.csdn.net/kokoyuo/article/details/52808510

Global site tag (gtag.js) - Google Analytics