`
bcyy
  • 浏览: 1919949 次
文章分类
社区版块
存档分类
最新评论

Velocity Tools例子

 
阅读更多

Apache官方网站Velocity Tools自带的例子(位置:\velocity-tools-1.4-src\examples\simple)。

新建一个Web Project,名称为Velocity。

在src下面实现一个ToyTool类,如下所示:

public class ToyTool
{
private String message = "Hello from ToyTool!";

public String getMessage()
{
return message;
}

public void setMessage(String m)
{
message = m;
}

/** To test exception handling in templates. */
public boolean whine() {
throw new IllegalArgumentException();
}

}

这个类实现了一个简单的JavaBean,带setter和getter,操作的属性是message。

模板文件为index.vm,内容如下所示:

<html>
<body>
I'm a velocity template.

#if( $XHTML )
#set( $br = "<br />" )
#else
#set( $br = "<br>" )
#end

$br
$br

Here we use a custom tool: $toytool.message

$br
$br

Here we get the date from the DateTool: $date.medium
</body>
</html>

在这个自带的例子中,并没有实际实现一个自己的Servlet,而是直接使用了org.apache.velocity.tools.view.servlet.VelocityViewServlet,该类位于\velocity-tools-1.4-src\src\java\org\apache\velocity\tools\view\servlet下面。

用到org.apache.velocity.tools.view.servlet.VelocityViewServlet,在该类中实现了对toolbox.xml的解析。可以在web.xml中对应的配置来了解到都配置了哪些项。

web.xml中配置如下所示:

<?xml version="1.0" encoding="UTF-8"?>
<web-app version="2.4"
xmlns="http://java.sun.com/xml/ns/j2ee"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://java.sun.com/xml/ns/j2ee
http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd">

<servlet>
<servlet-name>velocity</servlet-name>
<servlet-class>
org.apache.velocity.tools.view.servlet.VelocityViewServlet
</servlet-class>
<init-param>
<param-name>org.apache.velocity.toolbox</param-name>
<param-value>/WEB-INF/toolbox.xml</param-value>
</init-param>
<load-on-startup>10</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>velocity</servlet-name>
<url-pattern>*.vm</url-pattern>
</servlet-mapping>
<welcome-file-list>
<welcome-file>index.vm</welcome-file>
</welcome-file-list>

</web-app>

其中,toolbox.xml的内容如下所示:

<toolbox>
<xhtml>true</xhtml>
<tool>
<key>toytool</key>
<class>ToyTool</class>
</tool>
<data type="number">
<key>version</key>
<value>1.1</value>
</data>
<data type="boolean">
<key>isSimple</key>
<value>true</value>
</data>
<data type="string">
<key>foo</key>
<value>this is foo.</value>
</data>
<data type="string">
<key>bar</key>
<value>this is bar.</value>
</data>
<tool>
<key>map</key>
<class>java.util.HashMap</class>
</tool>
<tool>
<key>date</key>
<scope>application</scope>
<class>org.apache.velocity.tools.generic.DateTool</class>
</tool>
</toolbox>

将对应的jar包文件加入到CLASSPATH中,启动Tomcat Web Server ,在浏览器地址栏中键入http://localhost:8080/Velocity/index.vm就可以看到这个简单的例子运行的效果了:

I'm a velocity template.

Here we use a custom tool: Hello from ToyTool!

Here we get the date from the DateTool: 2008-4-19 21:23:50

既然,web.xml中指定了初始化参数:key为org.apache.velocity.toolbox,value为/WEB-INF/toolbox.xml文件,那么,在Web Server(这里使用Tomcat)启动的时候,就要解析/WEB-INF/toolbox.xml。

其实,这里隐藏了很多细节,需要解析的不仅仅是/WEB-INF/toolbox.xml,在解析它之前还有很多工作要做。

可以在VelocityViewServlet的源代码中看到实际的过程。VelocityViewServlet继承了HttpServlet,表现出了它是有生命周期的。其中在init方法中可以看到初始化过程:

public void init(ServletConfig config) throws ServletException
{
super.init(config);

// 根据config信息初始化Velocity,这时Web Server启动的时候要做的第一件事
initVelocity(config);

// 初始化toolbox
initToolbox(config);

// 当Velocity已经初始化完成之后,下面要做的一些事情:设置ContentType和编码等等等
defaultContentType =
(String)getVelocityProperty(CONTENT_TYPE, DEFAULT_CONTENT_TYPE);

String encoding =
(String)getVelocityProperty(RuntimeConstants.OUTPUT_ENCODING,
DEFAULT_OUTPUT_ENCODING);

// For non Latin-1 encodings, ensure that the charset is
// included in the Content-Type header.
if (!DEFAULT_OUTPUT_ENCODING.equalsIgnoreCase(encoding))
{
int index = defaultContentType.lastIndexOf("charset");
if (index < 0)
{
// the charset specifier is not yet present in header.
// append character encoding to default content-type
defaultContentType += "; charset=" + encoding;
}
else
{
// The user may have configuration issues.
velocity.warn("VelocityViewServlet: Charset was already " +
"specified in the Content-Type property. " +
"Output encoding property will be ignored.");
}
}

velocity.info("VelocityViewServlet: Default content-type is: " +
defaultContentType);
}

上面代码中,第一件事是initVelocity,即窄initVelocity方法中注册Velocity引擎

protected void initVelocity(ServletConfig config) throws ServletException
{
velocity = new VelocityEngine(); // 实例化一个VelocityEngine
setVelocityEngine(velocity); // 将已经创建的VelocityEngine设置到当前Velocity上下文中

// 注册
LogSystemCommonsLog.setVelocityEngine(velocity);

velocity.setApplicationAttribute(SERVLET_CONTEXT_KEY, getServletContext());

// 尝试读取VelocityTools 默认配置信息
try
{

/** 这里要读取Velocity的默认配置文件了,即org/apache/velocity/tools/view/servlet/velocity.properties文件,该文件默认设置如下所示:

# default to servletlogger, which logs to the servlet engines log
runtime.log.logsystem.class = org.apache.velocity.tools.view.servlet.ServletLogger

# by default, load resources with webapp resource loader
resource.loader = webapp
webapp.resource.loader.class = org.apache.velocity.tools.view.servlet.WebappLoader

*/
ExtendedProperties defaultProperties = loadDefaultProperties();
velocity.setExtendedProperties(defaultProperties);
}
catch(Exception e)
{
log("VelocityViewServlet: Unable to read Velocity Servlet configuration file: ", e);
throw new ServletException(e);
}

// velocity.properties文件是可以由用户自己根据需要配置的,如果用户自己重新设置了该文件,在这里解析
try
{
ExtendedProperties p = loadConfiguration(config);
velocity.setExtendedProperties(p);
}
catch(Exception e)
{
log("VelocityViewServlet: Unable to read Velocity configuration file: ", e);
log("VelocityViewServlet: Using default Velocity configuration.");
}

// 当velocity.properties文件加载完成,初始化VeloccityEngine
try
{
velocity.init();
}
catch(Exception e)
{
log("VelocityViewServlet: PANIC! unable to init()", e);
throw new ServletException(e);
}
}

接着就是initToolbox,开始解析/WEB-INF/toolbox.xml文件,initToolbox方法实现如下:

protected void initToolbox(ServletConfig config) throws ServletException
{
// 获取在web.xml中设置的toolbox.xml
String file = findInitParameter(config, TOOLBOX_KEY);
if (file == null)
{
// ok, look in the default location
file = DEFAULT_TOOLBOX_PATH;
velocity.debug("VelocityViewServlet: No toolbox entry in configuration."
+ " Looking for '" + DEFAULT_TOOLBOX_PATH + "'");
}

// 获取一个管理toolbox.xml的管理toolboxManager
toolboxManager =
ServletToolboxManager.getInstance(getServletContext(), file);
}

ToolboxManager是一个接口:

package org.apache.velocity.tools.view;

import java.util.Map;
public interface ToolboxManager
{
void addTool(ToolInfo info);
void addData(ToolInfo info);
Map getToolbox(Object initData);

}

它有一个实现子类XMLToolboxManager,可以完成对XML配置文件(比如toolbox.xml文件)的一些操作,其中,XMLToolboxManager类方法load实现了对XML文件的加载和解析:

public void load(InputStream input) throws Exception
{
LOG.trace("Loading toolbox...");

Digester digester = new Digester();
digester.setValidating(false);
digester.setUseContextClassLoader(true);
digester.push(this);
digester.addRuleSet(getRuleSet());
digester.parse(input);

LOG.trace("Toolbox loaded.");
}

分享到:
评论

相关推荐

    velocity例子

    6. **Velocity工具箱 (Velocity Tools)**: Velocity Tools是Velocity的一个扩展库,提供了许多有用工具,如日期格式化、国际化、URL生成等。这些工具可以在Velocity模板中直接使用,增强模板的功能。 7. **模板设计...

    Spring Velocity简单的一个例子(转)

    Spring Velocity是一个将Velocity模板引擎与Spring框架集成的示例,这个例子主要展示了如何在Spring应用中使用Velocity来渲染动态内容。Velocity是一个Java模板引擎,它允许开发者将逻辑和表示分离,使得网页设计...

    velocity开发包vm模板引擎

    在这个例子中,`$title` 和 `$username` 是从Java上下文中获取的变量,`#formatDate()` 是Velocity Tools提供的一个函数,用于格式化日期。 总的来说,Velocity以其简洁的语法和良好的可维护性,为Java Web开发提供...

    SpringMVC3+velocity最简单配置例子

    1. **添加依赖**: 在项目中引入SpringMVC和Velocity的相关库,通常包括`spring-webmvc`和`velocity`或者`velocity-tools`。 2. **配置SpringMVC**: 配置`DispatcherServlet`,指定处理器映射器、视图解析器等。对于...

    Velocity

    此外,还可以通过 `VelocityTools` 注册工具类,将常用的 Java 类库方法暴露给模板使用,例如日期格式化、URL编码等。 **5. 与其他技术的集成** Velocity 可以轻松地与Spring、Struts等其他Java Web框架集成,提供...

    velocity官方工具包

    官方工具包中的例子通常包括基本的变量引用、指令的使用、以及如何将Velocity集成到Spring等框架中。通过这些示例,用户可以直观地了解Velocity的工作原理,学习如何有效地使用Velocity来生成动态内容。 ### 扩展与...

    Velocity模板邮件发送例子(Spring框架)(可通用,支持多扩展)

    同时,还需要添加Velocity的jar包,如`velocity.jar`和`velocity-tools-view.jar`。 接下来,我们需要配置Spring。在`applicationContext.xml`或对应的配置文件中,定义Velocity的视图解析器(`...

    velocity-1.6.1.tar.gz

    2. **Velocity Tools**:提供了一系列工具类和模块,帮助简化模板开发,如ViewTools、ValidationTools等。 3. **Velocity Examples**:示例代码,帮助开发者理解和学习如何使用Velocity。 4. **Documentation**:...

    Velocity 入门

    - **Velocity 工具**: 如 VelocityTools,提供了一些额外的工具,如 VelocityViewServlet,简化了 Web 应用中的整合工作。 - **模板设计原则**: 保持模板尽可能简洁,避免过多的逻辑处理,让模板专注于展示。 - **...

    Spring MVC+Maven+Velocity配置实例

    对于Velocity,需要添加velocity-engine-core和velocity-tools-view。确保版本与你的其他依赖兼容。 配置Spring MVC,需要在`web.xml`文件中声明DispatcherServlet,并配置Spring的上下文加载器监听器,以便初始化...

    Velocity java 模板

    3. **velocity工具箱(Velocity Tools)**:提供了一系列工具类,简化了在模板中处理日期、集合等操作,提高开发效率。 4. **VelocityEngine**:是Velocity的核心组件,负责解析模板、设置配置、管理上下文等任务。...

    vilocity简单例子

    这个文件通常在Velocity Tools项目中使用,它是一个配置文件,用于定义工具箱中的各种工具实例。在Vilocity中,工具是指可以方便地在模板中使用的Java对象。例如,你可能会在`toolbox.xml`中配置一个日期工具,以便...

    vmmaven:利用maven来学习Velocity技术

    在这个例子中,`$title`、`$user`和`${date}`是变量,它们将在运行时由Velocity引擎替换为实际值。 【Velocity上下文与数据注入】 在Java代码中,开发者需要创建一个Velocity上下文(VelocityContext),并将数据...

    模板引擎velocitye、nvelocitye手册

    5. **自定义和扩展**:Velocity 允许用户自定义工具包(Velocity Tools),扩展其功能,如自定义标签库(Taglibs)和宏库,以满足特定项目需求。 6. **性能优化**:Velocity 在处理大量数据和复杂模板时,能够保持...

    模板引擎--Veloctiy

    此外,它提供了丰富的工具集,如 VelocityTools,可以与Spring、Struts等框架无缝集成,进一步提升开发效率。 总的来说,Velocity作为模板引擎,通过其简单易用的模板语言和强大的功能,为Java Web开发提供了一种更...

    java代码生成器知识.pdf

    9. **代码生成框架**:有一些开源框架如Apache Velocity Tools、MyBatis Generator、JHipster等,它们提供了丰富的功能和配置选项,帮助开发者快速实现自定义的代码生成任务。 总的来说,Java代码生成器是软件开发...

    java代码生成工具

    - 在Java领域,有一些流行的代码生成工具,例如MyBatis的Generator、Apache Velocity Tools以及IntelliJ IDEA等IDE内置的代码生成功能。 2. **工具的使用**: - 使用代码生成工具通常需要配置模板、数据库连接...

    selenium+testng+reporting+ant框架

    5. **配置testng.xml**:定义测试套件文件,指定要运行的测试类和方法,例如在上述例子中,`login`、`configure`和`support`是需要运行的测试方法。 6. **运行测试**:在Eclipse中选择testng.xml文件并运行它作为...

Global site tag (gtag.js) - Google Analytics