注册 | 登录
收藏 | 帮助
热门文章
编辑推荐
相关文章  
使用Honeypots同计算机蠕虫病毒作
脚本图片类后门的完美使用方法
CPU使用频率100%一定是中毒了吗
我的黑色工具箱—几款黑客工具的
IIS的NSIISLOG.DLL溢出问题分析
菜鸟入门常用的八种安全工具使用
使用Windows防火墙十大经典问题荟
安全至上 网吧使用电脑必看5点技
让隐私高枕无忧 放心使用公用计算
使用TCP/IP协议栈指纹进行远程操
您现在的位置: 顶尖设计 >> IT学院 >> 编程开发 >> Java >> 文章正文
使用sitemesh建立复合视图 - 1.hello
作者:佚名  来源:不详  点击:  更新:2006-12-19
简介:

sitemesh是opensymphony团队开发的j2ee应用框架之一,旨在提高页面的可维护性和复用性。opensymphony的另一个广为人知的框架为webwork是用作web层的表示框架。他们都是开源的,可以在www.sf.net下找到。

应用于以下大项目的例子:http://opensource.thoughtworks.com/projects/sitemesh.html

  • www.jboss.org
  • www.theserverside.com
  • www.opensymphony.com
  • www.atlassian.com
简介:

sitemesh应用Decorator模式,用filter截取request和response,把页面组件head,content,banner结合为一个完整的视图。
通常我们都是用include标签在每个jsp页面中来不断的包含各种header, stylesheet, scripts and footer,现在,
在sitemesh的帮助下,我们可以开心的删掉他们了。如下图,你想轻松的达到复合视图模式,那末看完本文吧。

 

hello sitemesh:
  1. 在WEB-INF/web.xml中copy以下filter的定义:
    <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>
    <taglib> <taglib-uri>sitemesh-decorator</taglib-uri>
    <taglib-location>/WEB-INF/sitemesh-decorator.tld</taglib-location> </taglib>
    <taglib> <taglib-uri>sitemesh-page</taglib-uri>
    <taglib-location>/WEB-INF/sitemesh-page.tld</taglib-location> </taglib>

  2. copy所需jar和dtd文件至相应目录,访问opensymphony.sourceforge.net的cvs以获取sitemesh最新版本。 sitemesh.jar WEB-INF/lib sitemesh-decorator.tld WEB-INF sitemesh-page.tld WEB-INF
  3. 建立WEB-INF/decorators.xml描述各装饰器页面(可仿照sitemesh例子)。
    <decorators defaultdir="/_decorators">     
    <decorator name="main" page="main.jsp">
    <pattern>*</pattern> </decorator>
    </decorators>



  4. 建立装饰器页面 /_decorators/main.jsp
    <%@ page contentType="text/html; charset=GBK"%> 
    <%@ taglib uri="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>


  5. 建立一个的被装饰页面 /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标签。






  • 上一篇文章:
  • 下一篇文章:
  • 分享此文:该页面添加到 Mister Wong 添加到雅虎Yahoo!收藏 Add to:Del.icio.us Post to Furl Digg this 添加到Google书签 reddit spurl blogmarks 365Key 评论  收藏  分享  打印
     我来说两句
    姓名:       验证码:   
    主页: 
    评分: 1分 2分 3分 4分 5分
    本频道近期热评文章:
      关于我们 | 联系我们 | 站点地图 | 广告投放 | 友情链接 | 在线留言 | 版权申明
    版权所有 © 2004-2007 顶尖设计(bobd.cn)
    未经授权禁止转载,摘编,复制本站内容或建立镜像. 沪ICP备07504942号 
    网络110
    报警服务