`
wap
  • 浏览: 74281 次
  • 性别: Icon_minigender_1
  • 来自: 深圳
社区版块
存档分类
最新评论

Tiles和SiteMesh,谁更适合你?

阅读更多

前段时间因工作需要,再次对Tiles和SiteMesh进行了应用对比,接下来我简单阐述一下我目前的结论,有错的地方,希望有朋友能够给予指导

 

版本选择:Tiles 2.1.2   SiteMesh 2.4

 

因兄弟们极力推荐,说SiteMesh好,我问为什么?他们告诉我说,网上文章都说SiteMesh好。于是我首先到opensymphone下了SiteMesh来试用,地址:http://www.opensymphony.com/sitemesh/刚开始项目使用时,就感觉SiteMesh的配置很简单,基本参照sitemesh-blank.war的示例https://sitemesh.dev.java.net/files/documents/887/124380/sitemesh-blank.war去做,就很快能够使用了。不需要sitemesh.xml,只有一个decorators.xml配置文件就可以正常的工作了。

 

示例应用配置:

1、SiteMesh 2.4

web.xml

    <filter>
        <filter-name>sitemesh</filter-name>
        <filter-class>com.opensymphony.sitemesh.webapp.SiteMeshFilter</filter-class>
    </filter>

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

 

decorators.xml

<?xml version="1.0" encoding="ISO-8859-1"?>

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

    <decorator name="panel" page="panel.jsp"/>
    <decorator name="footer" page="footer.jsp"/>
</decorators>

 

main.jsp

<%@ taglib uri="http://www.opensymphony.com/sitemesh/decorator" prefix="decorator" %>
<%@ taglib uri="http://www.opensymphony.com/sitemesh/page" prefix="page" %>

<html>
    <head>
        <title>My Site - <decorator:title default="Welcome!" /></title>
        <decorator:head />
    </head>

    <body>
        <page:applyDecorator name="panel"/>
        <decorator:body />
        <p><small>(<a href="?printable=true">printable version</a>)</small></p>
        <page:applyDecorator name="footer"/>
    </body>
</html>

 

2、Tiles 2.1.2

web.xml

	<context-param>
		<param-name>
			org.apache.tiles.impl.BasicTilesContainer.DEFINITIONS_CONFIG
		</param-name>
		<param-value>/WEB-INF/tiles-defs-example.xml</param-value>
	</context-param>
	<listener>
		<listener-class>
			org.apache.tiles.web.startup.TilesListener
		</listener-class>
	</listener>

 

tiles-defs-example.xml

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE tiles-definitions PUBLIC
       "-//Apache Software Foundation//DTD Tiles Configuration 2.0//EN"
       "http://tiles.apache.org/dtds/tiles-config_2_0.dtd">

<!-- Definitions for Tiles documentation   -->

<tiles-definitions>
	
	<definition name="basic" template="/decorators/main.jsp">
		<put-attribute name="title" value="example" />
		<put-attribute name="menu" value="/decorators/menu.jsp" />
		<put-attribute name="body" value="/decorators/blank.jsp" />
		<put-attribute name="footer" value="/decorators/footer.jsp" />
	</definition>

	<definition name="example.*.*" extends="basic">
		<put-attribute name="body" value="/example/{1}/{2}.jsp"/>
	</definition>

</tiles-definitions>

 

main.jsp

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE wml PUBLIC "-//WAPFORUM//DTD WML 1.1//EN" "http://www.wapforum.org/DTD/wml_1.1.xml">
<%@ page language="java" contentType="text/vnd.wap.wml; charset=utf-8"
	pageEncoding="UTF-8"%>
<%@ taglib uri="http://tiles.apache.org/tags-tiles" prefix="tiles" %>
<wml>
<head>
	<meta http-equiv="Cache-Control" content="max-age=0" forua="true" />
</head>
<card title='<tiles:getAsString name="title"/>'>
<tiles:insertAttribute name="menu" />
<tiles:insertAttribute name="body" />
<tiles:insertAttribute name="footer" />
</card>
</wml>

 

眼尖的朋友有没有发现?以前我写过一篇文章说《tiles不支持通配,spring支持》,这个文章可以废除了,Tiles 2.1.2支持通配了!!!是个非常有用的功能,项目当中遵循一个约定,我的一个项目中的配置就是几行!

 

3、直接用jsp路径访问

 

这项对比,虽然Tiles能够使用<tiles>标签做到,但是终究必须在第个页面加上<tiles>,多打那么几行!

而sitemesh基本不需要你做什么了,他会自动把你访问的jsp文件渲染到帧框中去。

 

4、servlet等MVC、集成模式访问

 

大多数项目团队,都会有一定的MVC约束机制。经过进一步集成进我的引擎框架的过程中时,比如我需要一个这样的函数,是能够直接渲染页面的功能:

 

public void render(String def) throws Exception {
	// 2.0.4版本使用TilesAccess,2.1.2版本时,使用ServletUtil工具.
        TilesContainer container;
        if ( tilesVersion.startsWith("2.0"))
	container = TilesAccess.getContainer(servletContext());
        else
                container = ServletUtil.getContainer(servletContext);
        container.render(def,request,response);
}

 

然后在其他Servlet或者bean中调用

render("example.entityA.edit");

 

我原以为sitemesh在代码内可以直接forward("/example/entityA/edit.jsp")就可以。但是不对,sitemesh不能通过servlet的api函数达到渲染效果,必须使用让用户浏览器发生行为的动作才能有效激活渲染,比如redirect。

 

SiteMesh暂时没有对这种应用需求考虑好。我参考了struts2和sitemesh的PageTag的代码,发现sitemesh的代码内部耦合性太强,需要对sitemesh内部好多类熟悉才能真正应用好。写一段类似以上面render方法时,要用到好多Servlet API不说,你只看看以下要用到sitemesh的类:

要用到的sitemesh内部类 写道
PageParser
Page
PageRequestWrapper
PageResponseWrapper
PageContext
Decorator
DecoratorManager
Config
Factory

 你就明白,那是多么复杂的一件事情。

 

我的总体认识是:

 

sitemesh的优点是是配置简单,方便快捷,适合的项目应该是主要以jsp作为主控制器的项目,比如项目是以jsp为主去开发,相信sitemesh对这样的项目会如虎添翼!或者你直接采用struts-sitemesh这样的第三方组件,也是可行的。缺点是对底层支持、api支持暂时不够,相信将来sitemesh会提供一个很好用的接口的,但目前不行!

 

最后,我基于这两个版本的对比,还是全面采用tiles 2.1.2!

推荐对MVC有一定约束期望的团队采用Tiles,我个人认为tiles在国际化、性能、灵活性方面更胜一筹。

 

 

以上仅个人之解,如有不正确的地方,欢迎朋友们给予指导!

 

8
2
分享到:
评论
4 楼 mqeefqfn 2013-09-02  
个人感觉性能不是这两个框架的主要选择限制因素,要想性能高 那就页面静态化处理。个人还是觉得sitemesh要简单的多,我在项目中就应用了sitemesh3 虽然是alpha版本,但是没有什么问题,用spring mvc做的mvc框架 没用struts.在controller里面可以直接 forward 或者redirect sitemesh照样可以渲染,没有遇到楼主说的那个问题。感觉tiles有点过于繁琐了。sitemesh3连页面的标签库都不需要引入了,它会解析你的response,同时也支持通配符路径
3 楼 huang_yong 2012-08-19  
jiasky 写道
你好,你写的确实很有见解。万一哪天面试官问我:“你说前者性能优,你测试过两者的性能吗,怎么测的?”我该怎么回答??

推荐你一篇文章,可以了解一下:http://www.iteye.com/topic/715100,希望对你有帮助!
2 楼 逃不过 2010-07-12  
第六感告诉我,前者性能不行
1 楼 jiasky 2010-03-19  
你好,你写的确实很有见解。万一哪天面试官问我:“你说前者性能优,你测试过两者的性能吗,怎么测的?”我该怎么回答??

相关推荐

    使用sitemesh替换tiles2,spring mvc+spring web flow+sitemsh

    NULL 博文链接:https://clongjava.iteye.com/blog/1350754

    jWebBox2:纯粹的面向对象的JSP布局工具-开源

    JWebBox2.0.0是Java服务器页面(JSP)项目中使用的小型布局工具,起着Tiles和SiteMesh的作用,但是它是纯面向对象设计的,没有XML文件,没有标签,功能强大但简单(仅1个Java类),并且易于使用,可用于构建整个网站...

    struts-2.3.30-all所有jar包

    tiles-request-servlet-wildcard-1.0.1.jar, tiles-request-velocity-1.0.1.jar, tiles-servlet-2.2.2.jar, tiles-template-2.2.2.jar, tiles-velocity-3.0.1.jar, velocity-1.6.4.jar, velocity-tools-1.3.jar, ...

    struts-2.5.2-all所有jar包

    tiles-autotag-core-runtime-1.1.0.jar, tiles-core-3.0.5.jar, tiles-el-3.0.5.jar, tiles-freemarker-3.0.5.jar, tiles-jsp-3.0.5.jar, tiles-ognl-3.0.5.jar, tiles-request-api-1.0.6.jar, tiles-request-...

    struts-2.5.10-all所有jar包

    struts2-tiles-plugin-2.5.10.jar,tiles-api-3.0.7.jar,tiles-autotag-core-runtime-1.2.jar,tiles-core-3.0.7.jar,tiles-el-3.0.7.jar,tiles-freemarker-3.0.7.jar,tiles-jsp-3.0.7.jar,tiles-ognl-3.0.7.jar,tiles...

    271个java需要用的jar包

    tiles-request-servlet-wildcard-1.0.1.jar tiles-request-velocity-1.0.1.jar tiles-servlet-3.0.1.jar tiles-template-3.0.1.jar tiles-velocity-3.0.1.jar tomcat-juli.jar velocity-1.6.4.jar velocity-tools-...

    Struts2-3.24集合jar

    struts2-config-browser-plugin-2.3.24.jar, struts2-core-2.3.24.jar, struts2-jasperreports-plugin-2.3.24.jar, struts2-jfreechart-plugin-2.3.24.jar, struts2-pell-...struts2-tiles-plugin-2.3.24.jar,

    Struts2 in action中文版

    第一部分 Strut 2:一个全新的框架 ...15.6 Tiles和Struts 2 325 15.6.1 关注网站的界面外观 325 15.6.2 配置相互关系 326 15.6.3 使用声明性架构 329 15.6.4 使用Tiles控制器准备网页内容 331 15.7 小结 332

    Struts2开发常用jar包

    包含struts2-core-2.5.10.1.jar,struts2-jfreechart-...struts2-sitemesh-plugin-2.5.10.1.jar,struts2-spring-plugin-2.5.10.1.jar,struts2-testng-plugin-2.5.10.1.jarstruts2-tiles-plugin-2.5.10.1.jar等jar包

Global site tag (gtag.js) - Google Analytics