- 浏览: 159487 次
- 性别:
- 来自: 奥克兰
文章分类
最新评论
-
u012625419:
...
CXF之用spring配置服务端和客户端实例(转) -
bambooshangye:
CXF之用spring配置服务端和客户端实例(转) -
最佳蜗牛:
写的很好,谢谢!
tomcat下的server.xml文件和context.xml (转) -
mohaowen1989:
亲 有中文版的么?在grails基础上的spring-secu ...
Simplified Spring Security with Grails(转) -
douhongyang:
挺好,,思路很清晰,
spring security详解教程 (转)
How Does It Work?
SiteMesh implements a page filter, taking advantage of one of the lesser-known features of the servlet specification. Let's imagine you have a simple JSP that returns the current date and time. Ordinarily, the request for the page comes in to the application server, the page is rendered, and then the results are returned to the web browser. SiteMesh, as a page filter, takes the page after it is rendered and performs additional processing before returning the document to the web browser. This change is most simply described as the additional step shown between Figure 1 and Figure 2.
Figure 1. Normal Page Rendering
Figure 2. SiteMesh Page Rendering
Let's look at a simple example of this. Consider the following simple JSP:
<html> <head> <title>Simple Document</title> </head> <body> Hello World! <br /> <%= 1+1 %> </body> </html>
You'll notice that the page has a title and a body (like any ordinary HTML page). You'll notice a tiny bit of JSP code -- this will be rendered just as you would expect. Indeed, you can use any and all features that you would expect, and you link between the various JSP and other resources just as you might expect.
Now, let's look at a simple SiteMesh "decorator" page. Listing 2 shows a JSP page, called by SiteMesh.
<%@ taglib uri="sitemesh-decorator" prefix="decorator" %> <html> <head> <title> My Site - <decorator:title default="Welcome!" /> </title> <decorator:head /> </head> <body> <h1><decorator:title default="Welcome!" /></h1> <p><decorator:body /></p> <p><small> (<a href="?printable=true">printable version</a>) </small></p> </body> </html>
Looking at the decorator, we can see a few interesting things. First,
a SiteMesh taglib is introduced in the first line. This taglib includes
everything required to work with the original page. You can see that we
use two of the SiteMesh declared tags, <decorator:title>
and <decorator:body>
. Not surprisingly, the <decorator:title>
returns the contents of the <title>
tag in the original page, and <decorator:body>
the content. We're making a few fairly radical changes to the page, including repeating the title both in the HEAD
element as well as the BODY
. We're also adding a link to a printable version of the page.
For comparison, Figure 3 shows the rendered original page and Figure 4 the rendered decorated page. Notice the appearance of the title text both in the browser window title bar and in the HTML of the page in the decorated page. You'll also notice that we added a printable page link, as well -- we'll come back to this later.
Figure 3. Original Undecorated Page
Figure 4. Decorated Page
Obviously, this is a much cleaner system for applying traditional
header and footer content than using include directives (such as <jsp:include page="foo.jsp" flush="true" />
).
It's much more flexible and natural, and encourages JSP pages with no
navigation or other presentation data. I have found that a combination
of decorators and CSS overrides of standard HTML tags allows me to
virtually eliminate formatting information from my JSP pages.
Installing SiteMesh
Note that the screenshots, etc. are based on Windows XP Professional, Tomcat 5.0.19 , and Java 2 SDK 1.4.2_03. I'm going to assume that you have installed and are able to get Tomcat working. You might have to tweak things slightly, but I've gotten all of this to work fine on Tomcat 4.1 and WebLogic as well, and SiteMesh lists many other supported web application servers.
SiteMesh 2.0.1, the version described in this article, can be downloaded here . There are four files available for download from SiteMesh's java.net project repository. The sitemesh-2.0.1.jar file is just the core JAR file, sitemesh-2.0.1-sources.zip is self-describing, and sitemesh-example.war provides a complex example showing some of SiteMesh's more advanced features.
To keep things simple, we'll start with the sitemesh-blank.war file, building and modifying as we go along. Instead of just dropping the WAR file into our Tomcat webapps directory, we'll crack open the WAR open and drop it in uncompressed, as shown in Figure 5.
Figure 5. SiteMesh Blank WAR Contents
There are a number of files here, so let's take a moment to describe what they do.
web.xml
First, the WEB-INF/web.xml file, shown in Listing 3, contains directives to install the SiteMesh filter and the taglib libraries. If you're adding SiteMesh to an existing web application, you'll need to add these directives to your WEB-INF/web.xml file.
<?xml version="1.0" encoding="ISO-8859-1"?> <!DOCTYPE web-app PUBLIC "-//Sun Microsystems, Inc.//DTD Web Application 2.3//EN" "http://java.sun.com/dtd/web-app_2_3.dtd"> <web-app> <!-- Start of SiteMesh stuff --> <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>*.jsp</url-pattern> </filter-mapping> <taglib> <taglib-uri>sitemesh-page</taglib-uri> <taglib-location>/WEB-INF/sitemesh-page.tld</taglib-location> </taglib> <taglib> <taglib-uri>sitemesh-decorator</taglib-uri> <taglib-location>/WEB-INF/sitemesh-decorator.tld</taglib-location> </taglib> <!-- End of SiteMesh stuff --> </web-app>
Note: you'll notice that I've flagged the url-pattern
line -- if you are using Tomcat 5 (instead of Tomcat 4) you'll need to change the pattern from the default *
to something like *.jsp
. The *
pattern is not allowed under the latest servlet specification.
decorators.xml
The WEB-INF/decorators.xml
file is used to bind a decorator name to a specific JSP decorator file. So, for example, we might bind a decorator named handheld
to the JSP page decorator minimal.jsp
.
<decorators defaultdir="/decorators"> <decorator name="main" page="main.jsp"> <pattern>*</pattern> </decorator> <decorator name="panel" page="panel.jsp"/> <decorator name="printable" page="printable.jsp"/> </decorators>
As we can see in this code listing, we define three decorators, and
then bind them to three similarly named JSP pages. We also see that the
default decorator, main.jsp
, will be applied for files by default.
By default, SiteMesh will use the following logic to determine what decorator to apply:
This logic is expressed in described in the sitemesh-2.0.1.jar file at \com\opensymphony\module\sitemesh\factor\sitemesh-default.xml . You can override this behavior with a wide variety of built-in mappers for things like language, client operating system, web browser/user agent, etc. by creating a WEB-INF\sitemesh.xml file. You'll find an example of this included in the sitemesh-example.war file. |
- Does the page specifically request a decorator using a meta decorator tag?
- Is the page a frame set (if so, don't apply a decorator)?
- Does the page have a
printable=true
parameter> (If so, use the printable decorator.) - Does the page specifically request a decorator by the decorator file name?
- Does the page match a pattern in the decorators.xml file?
Conceptually, the first rule that evaluates to true determines the decorator that is used. In the example above, when the printable=true
parameter is present, the printable.jsp
decorator (rule #3) is used instead of the main.jsp
(matched in rule #5). In SiteMesh, these rules are described as mappers
.
decorators/*.jsp
The three files in the decorators directory are the various decorator JSP files, as described by decorators.xml . We saw an example of a simple decorator above, and we'll look at a more sophisticated example later in this article.
sitemesh-2.0.1.jar
This is the main SiteMesh binary, typically installed in the WEB-INF/lib directory. You can find the Javadoc for this library at www.opensymphony.com/sitemesh/api .
*.tld
SiteMesh uses two tag libraries, but most users will only need the decorator tags (sitemesh-decorator.tld
). You can find documentation on these at www.opensymphony.com/sitemesh/tags.html
. We've already touched on the main tags, used to retrieve the head, title, and body. We'll look at the remaining tag, getProperty
, in the next section.
Advanced SiteMesh
One of the more powerful abilities of SiteMesh is to use the ordinary HTML meta
tag (for example, <meta name="foo" content="bar">
)
to pass information from the base page to the decorator. For example,
let's say that we would like to define the author of an HTML page using a
meta
tag, as shown below.
<html> <meta name="author" content="test@example.com"> <head> <title>Simple Document</title> </head> <body> Hello World! <br /> <%= 1+1 %> </body> </html>
We can make a decorator "smart" enough to know to look for this meta
tag, and if present, generate the appropriate HTML:
<%@ taglib uri="sitemesh-decorator" prefix="decorator" %> <decorator:usePage id="myPage" /> <html> <head> <title>My Site - <decorator:title default="Welcome!" /> </title> <decorator:head /> </head> <body> <h1><decorator:title default="Welcome!" /></h1> <h3> <a href="mailto:<decorator:getProperty property="meta.author" default="staff@example.com" />"> <decorator:getProperty property="meta.author" default="staff@example.com" /> </a></h3><hr /> <decorator:body /> <p><small> (<a href="?printable=true">printable version</a>) </small> </p> </body> </html>
You'll notice that we use a default attribute in the getProperty
tag -- if no author is specified, we'll just assume that it was written
by the staff. If you decide to use this model for storing page
metadata, you'll want to work with your content developers and other
team members to determine what tags you want to use and how you'll be
using them. At the simple end, you may want to use meta
tags to describe things like the author and page timestamp. At the
complex end, you may do things like standardize on an XML file to manage
your site navigation and use a meta
tag to pass the page's node to the decorator.
The page that results from applying this decorator to the JSP page above is shown in Figure 6.
Figure 6. meta
Tag Displayed
These page attributes are powerful, and you can retrieve many different properties, not just the meta
tags (here's a list of generated page properties
).
After using SiteMesh for a while, you'll start thinking about HTML and
JSP as a mechanism for generating simple markup -- closer to the
original intent of HTML -- without having to make a full switch to an
XML/XSL or other template engine.
Summary
As we've seen, SiteMesh provides for a powerful, easy-to-use, non-intrusive mechanism for applying page templates. It's easy to envision a wide range of possible uses. For example, you might define a decorator that emits extra debugging information about the page, as determined by the browser (this is especially powerful when combined with a web browser that lets you set an arbitrary user-agent). You might define a decorator with a stripped-down XML output, allowing for easier automated testing. You can even use the decorator to grab content from other pages, for example, to simple portal-like capability.
Once you've gotten comfortable with sitemesh-blank.war , I'd suggest looking at sitemesh-example.war for more features and ideas.
Regardless of how you use SiteMesh, I've found that it lets me centralize a tremendous amount of code, moving it out of my presentation layer and into my decorators, without having to learn a new programming language or templating system.
Oh, and as a final note for those of you still interested in building web pages in assembly, check out home.worldonline.dk/viksoe/asmil.htm .
Good luck and happy coding!
发表评论
-
Java theory and practice: Are all stateful Web applications broken? (转)
2011-11-05 06:14 1212转自: http://www.ibm.com/deve ... -
Java SE 6 新特性: JMX 与系统管理(转)
2011-11-01 10:14 960转自: http://www.ibm.com/dev ... -
Top Ten Tomcat Configuration Tips(转)
2011-07-13 10:54 1602Coauthor's note: Now that writi ... -
Linux下两种自动启动Tomcat的方法(转)
2011-07-13 06:48 13052一. 简单的方法 ... -
Java 远程调用 debug (转)
2011-01-17 05:12 6014首先,JAVA自身支持调试功能,并提供了一个简单的调试工具-- ... -
tomcat下的server.xml文件和context.xml (转)
2010-12-06 09:01 2281<Server>元素 它代表 ... -
Portal(门户)是什么 (转)
2010-10-21 09:44 1020Portal 的组成可以分为三部份(1) Portal Ser ... -
JNDI到底是什么,有什么作用(转)
2010-09-05 16:52 1155JNDI的一篇文章 前端时间总是在搞不清JNDI ... -
JMX架构的了解 (转)
2010-08-27 09:58 949JMX应该说是关于网络应 ... -
Linux常用命令和Linux服务器配置(转)
2010-08-25 13:31 1366Linux常用命令和Linux服务器配置 一、添加用户use ... -
JVM调优总结 -Xms -Xmx -Xmn -Xss(转)
2010-08-20 11:17 660堆大小设置 JVM 中最大堆大小有三方 ... -
JVM分代垃圾回收策略的基础概念(转)
2010-08-20 11:13 943文章总结了JVM垃圾回 ... -
HotSpot JVM 垃圾收集原理(转)
2010-08-20 10:44 877目的: 本 ... -
Java Runtime Monitoring 的一些名词解释
2010-08-20 10:38 1181Process Memory ... -
Java Generics FAQs - Type Parameters (转)
2010-07-29 04:47 915Type Parameters ... -
web.xml 中的listener、 filter、servlet 加载顺序及其详解(转)
2010-07-07 10:05 2685一、 1、启动一个WEB项目的时候,WEB容器会去读取它的 ...
相关推荐
下面将详细介绍这四个组件及其在开发中的作用。 1. **WebWork**:WebWork是一个基于Action的MVC(Model-View-Controller)框架,它的核心是请求驱动的Action,通过ActionServlet来处理HTTP请求。WebWork提供了强大...
1.2.1 标签库介绍 13 1.2.2 拦截器应用目的 14 1.2.3 FilterDispatcher和Action概述 14 1.2.4 Struts2配置文件处理 15 1.2.5 OGNL介绍和类型转换目的 15 1.2.6 进行校验 16 1.2.7 Web项目国际化根由 16 1.2.8 ...
SiteMesh部分介绍了这个Web应用框架,它被用于页面布局装饰。文档中还提到了SiteMesh3以及如何使用SiteMesh2进行菜单高亮处理。 在介绍完前端技术之后,文档深入到了后端部分。首先是介绍Spring Restful框架的章节...
- **知识点**: 介绍了SiteMesh框架及其在Struts2中的集成方式。 - **核心内容**: - SiteMesh是一个页面布局框架,可以帮助开发者构建一致的网站布局结构。 - Struts2可以通过配置将SiteMesh与项目集成,实现统一...
- SiteMesh 页面布局框架简介:SiteMesh可以集成到Struts2,实现统一的页面布局。 第 2 章:Web基础技术简介 2.1 B/S 和 C/S 系统区别 B/S(Browser/Server)架构基于浏览器和服务器交互,而C/S(Client/Server)...
SiteMesh是一个用于Web应用的页面布局框架,Struts2可以与SiteMesh结合使用,实现页面布局的统一和标准化。 1.3 我们为什么要用 Struts2 尽管有其他现代框架出现,但Struts2仍因其成熟的社区支持、丰富的插件和良好...
本讲义详细介绍了 Struts2 的各个方面,旨在帮助开发者理解和掌握其核心概念与功能。以下是对讲义内容的详细概述: **第 1 章 Struts 过时了吗?** 1.1 **Struts 历史发展过程** Struts 作为MVC(模型-视图-控制...
- SiteMesh:Struts2整合了SiteMesh,用于实现页面布局和装饰功能,提高页面样式的一致性。 1.3 为什么使用Struts2 Struts2的优势在于其强大的控制层能力、灵活的配置方式以及对MVC模式的良好支持,这使得开发过程...
SiteMesh 是一个非常实用的工具,它允许开发者使用装饰器模式对页面进行统一布局,从而简化页面的制作过程。 - **特点**: - 支持页面的分块管理,如头部、主体和底部等。 - 可以通过配置文件灵活地控制页面布局...
- **知识点**: 介绍了Struts框架的发展历程,包括Struts 1.x版本到Struts 2.x版本的演进路径。 - **重要性**: 了解Struts的历史背景有助于理解其设计理念和技术特点。 - **1.2 Struts2的“简历”** - **1.2.1 ...
最后,SiteMesh页面布局框架的引入,使得开发者可以方便地实现统一的页面布局。 第二章则转向了Web基础技术,讲解了B/S(Browser/Server)和C/S(Client/Server)系统之间的差异,强调了Web应用的灵活性和可访问性...
- **第14章至第19章整合其他框架**:分别讲述了Struts2与其他流行框架(如Spring、JSF、SiteMesh、JasperReports、JFreeChart、Hibernate)的整合方法,扩展了Struts2的功能范围。 - **第20章至第21章案例分析**:...
接下来,我们会对Web基础技术进行简要介绍,包括B/S和C/S系统的区别,JSP和Servlet的工作原理,以及XML的使用,这些都是理解Struts2运作的基础。JSP作为视图层技术,与Servlet(控制器)配合,形成了动态网页的生成...
10. **SiteMesh**:页面布局管理工具。 11. **Spring**:Spring框架与WebWork的集成方法。 12. **Other Spring Integration**:除了基本的Spring框架之外,还有哪些Spring相关的组件可以与WebWork配合使用。 13. **...
本专题资料详细介绍了Struts2的核心工作流程与原理,以下是对该流程的深入解析: 1. **客户端请求**: 当用户在浏览器中输入URL(例如`http://localhost:8080/TestMvc/add.action`)时,发起一个HTTP请求。这个...
- **SiteMesh**:SiteMesh是一个页面布局框架,它可以与Struts2集成,实现全局的页面布局和装饰。 **1.3 为什么选择Struts2** Struts2的优势在于它简化了MVC架构的实现,提供了强大的动作映射、结果处理和数据绑定...
此外,该指南可能介绍了如何与其他数据库系统集成,如Microsoft SQL Server、IBM DB2、Oracle等,以及如何利用不同的数据源,如UCI Machine Learning Repository的数据集。这些数据集常用于演示和学习目的,帮助用户...
- 在Struts2中集成SiteMesh非常简单,只需要在配置文件中添加相应配置即可。 #### 三、为什么选择Struts2 - **Struts2的优势**: - Struts2具有高度的灵活性和可扩展性。 - 它支持多种数据库访问技术和框架,如...