美文网首页
C-Velocity(模板引擎) --- B版(官方API--工

C-Velocity(模板引擎) --- B版(官方API--工

作者: 鄙人_阿K | 来源:发表于2021-05-24 21:58 被阅读0次

    非框架类总纲

    https://www.jianshu.com/p/d0167f082cbf

    友情链接:Velocity-前传

    https://www.jianshu.com/p/b977f3f4e3d6

    官方文档

    http://velocity.apache.org/tools/3.1/apidocs/index.html

    一、velocity tools 介绍

    Velocity Tools 是 Velocity模板引擎的一个子项目,用于将 Velocity 与 Web开发环境集成的工具包。

    VelocityTools项目分为两个部分:GenericToolsVelocityView .

    • GenericTools : GenericTools是一组类,它们提供在标准Velocity项目中使用工具的基本基础结构,以及在通用Velocity模板中使用的一组工具。例如 : DateTool、NumberTool和RenderTool很多其他可用的工具
    • Velocity view : 包括所有的通用工具结构和在web应用程序的视图层中使用Velocity的专用工具。这包括用于处理Velocity模板请求的VelocityViewServletVelocityLayoutServlet、用于在JSP中嵌入Velocity的VelocityViewTag和用于在Velocity模板中嵌入JSP标记库的Maven插件。这里流行的工具是LinkTool和ParameterTool。

    二、GenericTools使用

    1、GenericTools介绍

    GenericTools : GenericTools是一组类,它们提供在标准Velocity项目中使用工具的基本基础结构,以及在通用Velocity模板中使用的一组工具。
    简单来说, GenericTools就是Velocity官方提供的一组可以在模板中使用的工具类库

    2、GenericTools环境搭建

    2-1、创建项目

    2-2、导入依赖

    <dependencies>
        <dependency>
            <groupId>org.apache.velocity</groupId>
            <artifactId>velocity-engine-core</artifactId>
            <version>2.2</version>
        </dependency>
        <dependency>
            <groupId>org.apache.velocity.tools</groupId>
            <artifactId>velocity-tools-generic</artifactId>
            <version>3.0</version>
        </dependency>
        <dependency>
            <groupId>junit</groupId>
            <artifactId>junit</artifactId>
            <version>4.12</version>
            <scope>test</scope>
        </dependency>
    </dependencies>
    
    <build>
        <plugins>
            <plugin>
                <groupId>org.apache.maven.plugins</groupId>
                <artifactId>maven-compiler-plugin</artifactId>
                <version>3.8.1</version>
                <configuration>
                    <source>8</source>
                    <target>8</target>
                    <encoding>utf-8</encoding>
                </configuration>
            </plugin>
        </plugins>
    </build>
    

    2-3、创建模板

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>Title</title>
    </head>
    <body>
    当前时间 : $date.get('yyyy-MM-dd HH:mm:ss')
    </body>
    </html>
    

    2-4、编写配置

    image.png
    <?xml version="1.0" encoding="UTF-8"?>
    <tools>
        <toolbox scope="application">
            <tool class="org.apache.velocity.tools.generic.DateTool"></tool>
        </toolbox>
    </tools>
    

    2-5、输出数据

    public void test2() throws IOException {
            // 创建引擎
            VelocityEngine ve = new VelocityEngine();
            // 设置模板加载路径,这里设置的是class下
            ve.setProperty(Velocity.RESOURCE_LOADER, "class");
            ve.setProperty("class.resource.loader.class", "org.apache.velocity.runtime.resource.loader.ClasspathResourceLoader");
            // 进行初始化操作
            ve.init();
    
            // 加载toolbox
            ToolManager manager = new ToolManager();
            manager.configure("configuration.xml");
    
            // 加载模板,设定模板编码
            Template tpl = ve.getTemplate("vms/01-velocitytools.vm", "UTF-8");
    
            // 设置初始化数据
            Context context = manager.createContext();
            context.put("now", new Date ());
    
            FileWriter fw  = new FileWriter("D:\\work\\demo1.html");
            //合并数据到模板
            tpl.merge(context, fw);
            //释放资源
            fw.close();
        }
    

    3、工具类及案例

    格式化工具类的主要作用就是对数据进行格式化之后输出 , 例如 : 日期格式化 , 数字格式化等 , GenericTools提供的工具类有很多 , 随着时间的推移很多工具类已经过期, 有更好更安全的替代方案, 这里我们仅仅介绍一些常用工具类

    1、DateTool

    用于访问和格式化日期以及格式化Date和Calendar对象。该工具还可以用于在各种日期类型之间进行转换。

    模板:

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>Title</title>
    </head>
    <body>
    年 : $date.getYear()
    月: $date.getMonth()
    日: $date.getDay()
    
    当前时间 : $date.format($now)
    当前时间 : $date.format("yyyy-MM-dd HH:mm:ss",$now)
    当前时间 : $date.get('yyyy-MM-dd HH:mm:ss')
    </body>
    </html>
    

    配置:

    <toolbox scope="application">
        <tool  key="date" class="org.apache.velocity.tools.generic.DateTool" format="yyyy-MM-dd"></tool>
    </toolbox>
    

    2、NumberTool

    用于访问和格式化任意数值类型对象。该工具还可以用于检索NumberFormat实例或与各种数字类型进行相互转换。

    模板:

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>Title</title>
    </head>
    <body>
    原始数据 : $myNumber          12.88
    格式化 : $number.format($myNumber)  12.88
    取整 : $number.integer($myNumber)      13
    </body>
    </html>
    

    配置:

    <toolbox scope="application">
        <tool key="number" class="org.apache.velocity.tools.generic.NumberTool" />
    </toolbox>
    

    3、MathTool、

    用于在Velocity中执行数学运算。

    模板:

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>Title</title>
    </head>
    <body>
    
    num1+num2 : $math.add($num1,$num2);
    num1-num2 : $math.sub($num1,$num2);
    num1*num2 : $math.mul($num1,$num2);
    num1/num2 : $math.div($num1,$num2);
    向上取整 : $math.ceil($math.div($num1,$num2))
    向下取整 : $math.floor($math.div($num1,$num2))
    四舍五入 : $math.roundTo(2,$math.div($num1,$num2))  ## 第一个参数保留的位数 , 第二个参数运算的值
    
    
    </body>
    </html>x
    

    配置:

    <toolbox scope="application">
        <tool key="math" class="org.apache.velocity.tools.generic.MathTool" />
    </toolbox>
    

    4、DisplayTool

    用于控制数据显示和隐藏 , 以及数据格式的处理

    模板:

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>Title</title>
    </head>
    <body>
    
    ## list方法用于展示数据或集合中的数据 , 默认的展示格式为 A, B and C
    默认输出格式 : $display.list($list)
    使用,分割输出 : $display.list($list,",")
    
    ## truncate方法用于字符串截取 , 默认截取30个长度
    字符串截取, 默认30个长度 : $display.truncate("truncate方法用于字符串截取默认截取30个长度")
    字符串截取, 给定20个长度 : $display.truncate("truncate方法用于字符串截取默认截取30个长度",20)
    字符串截取, 给定20个长度 : $display.truncate("truncate方法用于字符串截取默认截取30个长度",20,"")
    
    ## alt方法用于判断给定的数据是否为空 , 如果为空展示第二个参数 , 如果不为空展示数据本身
    不为空:$display.alt($num1,"num1不为空")
    为空:$display.alt($num3,"num3为空")
    
    </body>
    </html>
    

    配置:

    <toolbox scope="application">
        <tool key="display" class="org.apache.velocity.tools.generic.DisplayTool"/>
    </toolbox>
    

    5、EscapeTool

    用于对一些特殊字符进转义处理 , 例如 $ , #, & 等...

    模板:

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>Title</title>
    </head>
    <body>
    
        $velocity    -------转换 -------
        $esc.velocity($velocity)
    
        $html     -------转换  -------
        $esc.html($html)
    
        $url      -------转换 -------
        $esc.url($url)
        $esc.unurl($esc.url($url))
    
        $esc.dollar     ## $
        $esc.d          ## $
    
        $esc.hash       ## #
        $esc.h          ## #
    
        $esc.backslash  ## \
        $esc.b          ## \
    
        $esc.quote      ## "
        $esc.q          ## "
    
        $esc.singleQuote    ## '
        $esc.s              ## '
    
        $esc.exclamation    ## !
        $esc.e              ## !
    
    </body>
    </html>
    

    配置:

    <toolbox scope="application">
        <tool key="esc" class="org.apache.velocity.tools.generic.EscapeTool"/>
    </toolbox>
    

    6、FieldTool

    用于访问类中定义public修饰的静态常量

    6.1、定义MyConstants常量类

    public class MyConstants {
    
        public static  String COUNTER_NAME = "COUNTER";
    }
    

    6.2、定义Counter常量类

    public class Counter {
       public static Integer MAX_VALUE = 100 ;
       public static Integer MIN_VALUE = 100 ;
    }
    

    模板:

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>Title</title>
    </head>
    <body>
    
    ## 访问在配置中定义的静态常量
    获取MyConstants中的常量 : $field.COUNTER_NAME
    
    ## 通过一个类中的常量
    获取Counter类中的量 : $field.in("com.kk.counter.Counter").MAX_VALUE
    
    ## 传入一个对象的实例 , 通过对象的实例获取其类中定义的常量
    获取日历对象中的YEAR常量 : $field.in($calender).YEAR
    
    ## 默认情况下, 当我们查找了一个类的常量之后, 这个类回保存在FieldTool工具中, 可以直接获取下一个常量
    获取日历对象中的DATE常量 : $field.DATE  ## 因为之前已经获取过 , 所以可以直接获取
    
    </body>
    </html>
    

    配置:

    <toolbox scope="application">
        <tool key="field"  class="org.apache.velocity.tools.generic.FieldTool" include="com.kk.constants.MyConstants"/>
    </toolbox>
    

    include属性可以引入一些类, 引入之后想要获取其中的常量, 直接使用 $field.常量字段名称即可 ! 引入多个类以,分割

    7、ClassTool

    ClassTool用于访问一个类的Class对象信息以及其Filed , Method , Constructor等信息 , 它的设计没有考虑到代码的反射执行,因此无法通过反射执行代码。

    模板:

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>Title</title>
    </head>
    <body>
    
    ## 获取要查看的类上的所有注解 , 只有运行时期的注解才能够获取到
    注解 : $class.getAnnotations()
    构造方法 :
    #foreach($constructor in $class.getConstructors())
        $constructor
    #end
    属性 :
    #foreach($f in $class.getFields())
        $f
    #end
    方法 :
    #foreach($m in $class.getMethods())
        $m
    #end
    包名 : $class.getPackage()
    类名 : $class.getName()
    
    ## 也可以不通过配置文件 , 自己指定一个要查找的类
    包名 : $class.inspect("java.lang.String").getPackage()
    类名 : $class.inspect("java.lang.String").getName()
    构造方法 :
    #foreach($constructor in $class.inspect("java.lang.String").getConstructors())
        $constructor
    #end
    </body>
    </html>
    

    配置:

    <toolbox scope="application">
        <tool class="org.apache.velocity.tools.generic.ClassTool" inspect="com.kk.utils.Result" ></tool>
    </toolbox>
    

    inspect : 指定一个需要查找的类

    8、ContextTool

    用于获取Context中保存的数据和元数据

    模板:

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>Title</title>
    </head>
    <body>
    
    context中的所有key :
    #foreach( $key in $context.keys )
        $key
    #end
    <br>
    
    context中的所有value :
    #foreach( $value in $context.values )
        $value
    #end
    
    <br>
    
    context中的所有key-value :
    #foreach( $key in $context.keys )
        $key = $context.get($key)
    #end
    
    </body>
    </html>
    

    配置:

    <toolbox scope="request">
        <tool key="context" class="org.apache.velocity.tools.generic.ContextTool"/>
    </toolbox>
    

    需要注意的是在application作用范围中没有ContextTool , 所以scope需要指定为request

    9、RenderTool

    Render用于将给定的字符串当作VTL秩序

    模板:

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>Title</title>
    </head>
    <body>
    #set($list = [1,2,3] )
    #set($object = '$list' )
    #set($method = 'size()' )
    ## 将字符串当作VTL秩序
    $render.eval("${object}.$method")
    
    
    ## 使用当前上下文递归地评估包含VTL的字符串,并将结果作为字符串返回。
    #macro(say_hi)
        hello world!
    #end
    
    #set($foo = "#say_hi()")
    #set($bar = "$foo" )
    $render.recurse($bar)
    
    </body>
    </html>
    

    配置:

    <toolbox scope="request">
        <tool key="render" class="org.apache.velocity.tools.generic.RenderTool"></tool>
    </toolbox>
    

    使用recurse递归时 ,RenderTool 默认将递归限制为20个周期,以防止无限循环

    10、SortTool

    SortTool用于对集合和数组数据进行排序 , 在排序操作期间,通过调用compareTo() 来进行比较,但要调用compareToIgnoreCase()的字符串除外。将集合数据转化为合适的类型后 , 通过调用Collections.sort()来执行排序

    模板:

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>Title</title>
    </head>
    <body>
    
    简单类型排序 :
    #set($strList = $sorter.sort($strs))
    #foreach($str in $strList)
        $str
    #end
    
    对象类型排序 - 单个字段 :
    #set($users = $sorter.sort($userList,"age:asc"))
    #foreach($user in $users)
        $user.name : $user.age  :  $user.sex
    #end
    
    对象类型排序 - 多字段 :
    #set($users = $sorter.sort($userList,["sex:desc","age:asc"]))
    #foreach($user in $users)
        $user.name : $user.age  :  $user.sex
    #end
    </body>
    </html>
    

    配置:

    <toolbox scope="request">
        <tool key="render" class="org.apache.velocity.tools.generic.RenderTool"></tool>
    </toolbox>
    

    SortTool已经被标注为过期, 建议使用下面CollectionTool的排序方法

    11、CollectionTool

    CollectionTool允许用户对集合中包含的对象公开的任意任意属性集对集合(或数组,迭代器等)进行排序,并通过拆分字符串来生成数组。

    模板:

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>Title</title>
    </head>
    <body>
    
    简单类型排序 :
    #set($strList = $collection.sort($strs))
    #foreach($str in $strList)
        $str
    #end
    
    对象类型排序 - 单个字段 :
    #set($users = $collection.sort($userList,"age:asc"))
    #foreach($user in $users)
        $user.name : $user.age  :  $user.sex
    #end
    
    对象类型排序 - 多字段 :
    #set($users = $collection.sort($userList,["sex:desc","age:asc"]))
    #foreach($user in $users)
        $user.name : $user.age  :  $user.sex
    #end
    
    拆分字符串 :
    #set($str="hello word , how are you !")
    #foreach($s in $collection.split($str))
        $s
    #end
    
    
    </body>
    </html>
    

    配置:

    <tool key="collection" class="org.apache.velocity.tools.generic.CollectionTool" stringsDelimiter=" ">
    </tool>
    

    stringsDelimiter : 指定进行字符串分割时的分割符 , 默认是,

    12、XmlTool

    XmlTool用于读取和浏览XML文件。它底层使用dom4j为遍历XML文件提供完整的XPath支持。

    xml文件:

    <?xml version="1.0" encoding="UTF-8"?>
    <users>
        <user id="1" name="杨过" sex="男" age="18" > 喜欢看书 </user>
        <user id="2" name="小龙女" sex="男" age="18" > 喜欢睡觉 </user>
        <user id="3" name="郭靖" sex="男" age="18" > 喜欢玩游戏 </user>
        <user id="4" name="黄蓉" sex="男" age="18" > 喜欢喝酒 </user>
    </users>
    

    模板:

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>Title</title>
    </head>
    <body>
    
    $xml.find("//user[@id='1']")
    $xml.find("//user[@id='1']").attr("name")
    $xml.find("//user[@id='1']").text
    
    
    </body>
    </html>
    

    配置:

    <toolbox scope="application">
        <tool key="xml" class="org.apache.velocity.tools.generic.XmlTool"  resource="xml/user.xml"/>
    </toolbox>
    

    resource : 加载类路径下的XML资源
    source : 加载一个URL路径下的XML资源

    三、Velocity View

    1、Velocity View j介绍

    VelocityView包含所有GenericTools并添加了用于在Web应用程序(Java EE项目)的视图层中使用Velocity的基础结构和专用工具。这包括用于处理Velocity模板请求的VelocityViewServletVelocityLayoutServlet,以及用于将Velocity嵌入JSP中的VelocityViewTag

    2、环境搭建

    2-1、导入依赖(插件:锁定 JDK版本,Tomcat版本)

    <dependencies>
            <dependency>
                <groupId>org.apache.velocity</groupId>
                <artifactId>velocity-engine-core</artifactId>
                <version>2.2</version>
            </dependency>
            <dependency>
                <groupId>org.apache.velocity.tools</groupId>
                <artifactId>velocity-tools-generic</artifactId>
                <version>3.0</version>
            </dependency>
            <dependency>
                <groupId>org.apache.velocity.tools</groupId>
                <artifactId>velocity-tools-view</artifactId>
                <version>3.0</version>
            </dependency>
            <dependency>
                <groupId>junit</groupId>
                <artifactId>junit</artifactId>
                <version>4.12</version>
                <scope>test</scope>
            </dependency>
            <dependency>
                <groupId>org.apache.tomcat</groupId>
                <artifactId>tomcat-api</artifactId>
                <version>9.0.10</version>
                <scope>provided</scope>
            </dependency>
        </dependencies>
    
        <build>
            <plugins>
                <plugin>
                    <groupId>org.apache.maven.plugins</groupId>
                    <artifactId>maven-compiler-plugin</artifactId>
                    <version>3.8.1</version>
                    <configuration>
                        <source>11</source>
                        <target>11</target>
                        <encoding>utf-8</encoding>
                    </configuration>
                </plugin>
                <plugin>
                    <groupId>org.apache.tomcat.maven</groupId>
                    <artifactId>tomcat7-maven-plugin</artifactId>
                    <version>2.2</version>
                    <configuration>
                        <path>/</path>
                        <port>8080</port>
                        <uriEncoding>utf-8</uriEncoding>
                    </configuration>
                </plugin>
            </plugins>
        </build>
    

    2-2、配置Servlet

    在web.xml中配置整合VelocityViewServlet

    <?xml version="1.0" encoding="UTF-8"?>
    <web-app
            version="3.0"
            xmlns="http://java.sun.com/xml/ns/javaee"
            xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
            xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd">
    
        <servlet>
            <servlet-name>velocity</servlet-name>
            <servlet-class>org.apache.velocity.tools.view.VelocityViewServlet</servlet-class>
            <init-param>
                <param-name>org.apache.velocity.toolbox</param-name>
                <param-value>/WEB-INF/tools.xml</param-value>
            </init-param>
        </servlet>
    
        <servlet-mapping>
            <servlet-name>velocity</servlet-name>
            <url-pattern>*.vm</url-pattern>
        </servlet-mapping>
    </web-app>
    

    该配置表示拦截所有的vm结尾的请求 , vm就是velocity模板文件的扩展名

    2-3、引入配置文件
    在web.xml中可以引入的配置文件有两个 :

    • tools.xml : 配置页面使用的一些工具
    • velocity.properties : 配置一些日志, 编码, 宏等一些配置

    如果要引入配置文件, 官方建议将配置文件放置在web项目的/WEB-INF目录下

    2-3-1配置文件一:tools.xml

    <?xml version="1.0" encoding="UTF-8"?>
    <tools>
        <toolbox scope="application">
            <tool key="date" class="org.apache.velocity.tools.generic.DateTool" format="yyyy-MM-dd"></tool>
            <tool key="number" class="org.apache.velocity.tools.generic.NumberTool" />
            <tool key="math" class="org.apache.velocity.tools.generic.MathTool" />
            <tool key="display" class="org.apache.velocity.tools.generic.DisplayTool"/>
            <tool key="esc" class="org.apache.velocity.tools.generic.EscapeTool"/>
            <tool key="field"  class="org.apache.velocity.tools.generic.FieldTool" include="com.kk.constants.MyConstants"/>
            <tool key="class" class="org.apache.velocity.tools.generic.ClassTool" inspect="com.kk.utils.Result" ></tool>
            <tool key="sorter" class="org.apache.velocity.tools.generic.SortTool"/>
            <tool key="collection" class="org.apache.velocity.tools.generic.CollectionTool" stringsDelimiter=" "></tool>
            <tool key="xml" class="org.apache.velocity.tools.generic.XmlTool"  resource="xml/user.xml"/>
        </toolbox>
    
        <toolbox scope="request">
            <tool key="context" class="org.apache.velocity.tools.generic.ContextTool"/>
            <tool key="render" class="org.apache.velocity.tools.generic.RenderTool"></tool>
        </toolbox>
    </tools>
    

    2-3-2配置文件二:tools.xml
    官网截取,具体看官网(写法改成properties即可):http://velocity.apache.org/engine/devel/configuration.html#configuration-summary-tree

    context. +-- scope_control. +-- define = false
             |                  +-- evaluate = false
             |                  +-- foreach = true
             |                  +-- macro = false
             |                  +-- template = false
             |                  +-- *somebodymacro* = false
             +-- self_reference_key = *key_name*
    
    directive. +-- define.max_depth = 2
               +-- foreach. +-- max_loops = -1
               |            +-- skip_invalid = true
               +-- if.empty_check = true
               +-- parse.max_depth = 10
    
    event_handler. +-- include.class = *classname*, *classname* ...
                   +-- invalid_reference. +-- class = *classname*, *classname* ...
                                          +-- exception = false
                                          +-- null = false
                                          +-- quiet = false
                                          +-- tested = false
                   +-- method_exception.class = *classname*, *classname* ...
                   +-- reference_insertion.class = *classname*, *classname* ...
    
    introspector. +-- conversion_handler. +-- class = org.apache.velocity.util.introspection.TypeConversionHandlerImpl
                  |                       +-- instance = *Java Object instance*
                  +-- uberspect.class = org.apache.velocity.util.introspection.UberspectImpl
    
    parser. +-- allow_hyphen_in_identifiers = false
            +-- pool. +-- class = org.apache.velocity.runtime.ParserPoolImpl
            |         +-- size = 20
            +-- space_gobbling = lines
    
    resource. +-- default_encoding = UTF-8
              +-- loaders = file, ...
              +-- loader.*loader_name*. +-- class = *classname*
              |                         +-- instance = *Java Object instance*
              |                         +-- cache = false
              |                         +-- modification_check_interval = 2
              |                         +-- *loader_prop* = ...
              +-- manager. +-- cache. +-- class = org.apache.velocity.runtime.resource.ResourceCacheImpl
                           |          +-- default_size = 89
                           +-- class = org.apache.velocity.runtime.resource.ResourceManagerImpl
                           +-- instance = null
                           +-- log_when_found = true
    
    runtime. +-- custom_directives = *classname*, *classname* ...
             +-- interpolate_string_literals = true
             +-- log. +-- instance = *Java Object instance*
             |        +-- log_invalid_method_calls = true
             |        +-- log_invalid_references = true
             |        +-- name = org.apache.velocity
             |        +-- track_location = false
             +-- strict_math = false
             +-- strict_mode. +-- enable = false
             |                +-- escape = false
             +--string_interning = true
    
    velocimacro. +-- arguments.strict = false
                 +-- body_reference = false
                 +-- enable_bc_mode = false
                 +-- inline. +-- allow = true
                 |           +-- local_scope = false
                 |           +-- replace_global = false
                 +-- library. +-- autoreload = false
                              +-- path = velocimacros.vtl
    

    3、案例:使用 Velocity View

    当我们配置好了之后使用VelocityView非常简单 , 只需要将数据保存在web项目的中 , 在velocity模板中就可以直接获取数据展示了

    3-1、展示基础数据

    3-1-1、编写模板:在web项目下创建user-info.vm模板文件

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>Title</title>
    </head>
    <body>
    欢迎您: $name
    </body>
    </html>
    

    3-1-2、创建Servlet

    public class UserInfoServlet extends HttpServlet {
    
        protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
            doGet(request, response);
        }
    
        protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
            //在request域保存数据
            request.setAttribute("name",request.getParameter("name"));
            //设置响应数据格式以及字符集
            response.setContentType("text/html;charset=utf-8");
            request.getRequestDispatcher("/vms/user-info.vm").forward(request,response);
        }
    }
    

    3-1-3、配置Servlet

    <servlet>
        <servlet-name>UserInfoServlet</servlet-name>
        <servlet-class>com.kk.servlet.UserInfoServlet</servlet-class>
    </servlet>
    <servlet-mapping>
        <servlet-name>UserInfoServlet</servlet-name>
        <url-pattern>/user/info</url-pattern>
    </servlet-mapping
    

    3-2、展示列表数据

    3-2-1、编写模板:在项目下创建user-list.vm用于展示列表数据

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>Title</title>
    </head>
    <body>
    
    <table>
        <tr>
            <td>编号</td>
            <td>姓名</td>
            <td>性别</td>
            <td>年龄</td>
            <td>操作</td>
        </tr>
        #foreach($user in $userList)
            <tr>
                <td>$foreach.index</td>
                <td>$user.name</td>
                <td>$user.sex</td>
                <td>$user.age</td>
                <td>
                    <a href="">编辑</a>
                    <a href="">删除</a>
                </td>
            </tr>
        #end
    
    </table>
    
    </body>
    </html>
    

    3-2-2、创建Servlet

    public class UserListServlet extends HttpServlet {
    
        protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
            doGet(request, response);
        }
    
        protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
            List<User> userList = new ArrayList<User>();
            userList.add(new User("吕布",38,"man"));
            userList.add(new User("貂蝉",16,"woman"));
            userList.add(new User("刘备",28,"man"));
            userList.add(new User("关羽",25,"man"));
            userList.add(new User("张飞",20,"man"));
            userList.add(new User("甄宓",21,"woman"));
    
            request.setAttribute("userList",userList);
    
            response.setContentType("text/html;charset=utf-8");
            request.getRequestDispatcher("/vms/user-list.vm").forward(request,response);
        }
    }
    
    

    3-2-3、配置Servlet

    <servlet>
        <servlet-name>UserListServlet</servlet-name>
        <servlet-class>com.kk.servlet.UserListServlet</servlet-class>
    </servlet>
    <servlet-mapping>
        <servlet-name>UserListServlet</servlet-name>
        <url-pattern>/user/list</url-pattern>
    </servlet-mapping>
    

    3-3、使用Tools工具
    因为我们在配置VelocityViewServlet的时候已经加载了tools.xml配置文件 , 所以直接在模板文件中使用工具即可
    例如 : 列表页面我们展示编号使用的是$foreach.index , 是从0开始的, 现在想让编号从1开始 , 可以使用MathTool , 在index的基础上+1

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>Title</title>
    </head>
    <body>
    <table>
        <tr>
            <td>编号</td>
            <td>姓名</td>
        </tr>
        #foreach($user in $userList)
            <tr>
                <td>$math.add($foreach.index,1)</td>
                <td>$user.name</td>
            </tr>
        #end
    </table>
    </body>
    </html>
    

    4、工具类及案例

    4-1、CookieTool:用于获取和创建Cookie
    模板:

    <body>
    $cookie.username ## 获取指定名称的cookie值
    $cookie.add("phone",'18917009089')  ## 创建并设置cookie
    </body>
    

    配置:

    <toolbox scope="request">
        <tool key="cookie" class="org.apache.velocity.tools.view.CookieTool"/>
    </toolbox>
    

    4-2、BrowserTool:用于获取客户端浏览器,操作系统,设备,语言等信息。

    模板:

    <body>
    设备信息 :   $browser.device <br>
    用户客户端 : $browser.userAgentString   <br>
    渲染引擎 : $browser.renderingEngine.name<br>
    操作系统 : $browser.operatingSystem.name<br>
    IP地址 : $browser.iPAddress<br>
    </body>
    

    配置:

    <toolbox scope="session">
        <tool key="browser" class="org.apache.velocity.tools.view.BrowserTool"  />
    </toolbox>
    

    可以定义在在requestsession范围 , 建议在session范围使用

    servlet:

    public class BrowserToolServlet extends HttpServlet {
        protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
            doGet(request, response);
        }
    
        protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
            response.setContentType("text/html;charset=utf-8");
            request.getRequestDispatcher("/vms/tool-browser.vm").forward(request,response);
        }
    }
    
    <servlet>
        <servlet-name>BrowserToolServlet</servlet-name>
        <servlet-class>com.kk.servlet.BrowserToolServlet</servlet-class>
    </servlet>
    <servlet-mapping>
        <servlet-name>BrowserToolServlet</servlet-name>
        <url-pattern>/user/browser</url-pattern>
    </servlet-mapping>
    

    4-3、ParameterTool:用户获取请求中的参数

    模板:

    <body>
    
    ## 获取所有的请求参数
    #set($parameters = $params.all)
    #foreach($entry in $parameters.entrySet())
        $entry.key : $entry.value  <br>
    #end
    
    <hr>
    
    ## 获取一个key对应一个值的参数
    name : $params.getString("username") <br>
    
    ## 获取一个key对应多个值得参数
    hobby : $params.getStrings("hobby")
    
    </body>
    

    配置:

    <toolbox scope="request">
        <tool key="params" class="org.apache.velocity.tools.view.ParameterTool"/>
    </toolbox>
    

    4-4、ViewContextTool
    ViewContextTool是GenericTools中ContextTool的扩展 , 可以Velocity容器中的所有数据 , 包括HttpServletRequest, HttpSession and ServletContext中的数据

    模板:

    <body>
    ## 获取velocity容器中的所有数据
    #foreach( $key in $context.keys )
        $key = $context.get($key)   <br>
    #end
    </body>
    

    配置:

    <toolbox scope="request">
       <!-- <tool key="context" class="org.apache.velocity.tools.generic.ContextTool"/>-->
        <tool key="context" class="org.apache.velocity.tools.view.ViewContextTool"/>
    </toolbox>
    

    四、自定义tools工具类

    VelocityTools中定义了很多Tools供我们使用 , 如果官方提供的还不能满足我们的需求, 我们也可以自己定义工具类 , 自定义工具类有一些要求 , 如下 :

    1. 工具类必须声明为public
    2. 工具类中必须提供公共的无参构造方法

    下面我们可以定义一个字符串的Tools类, 帮助我们对字符串进行特殊的处理 , 主要有二个功能

    1. 判断字符串是否为Null或者""
    2. 随机生成一个指定位数的数字字符串

    1、编写工具类

    package com.kk.tools;
    import org.apache.commons.lang3.RandomStringUtils;
    import org.apache.velocity.tools.config.DefaultKey;
    import org.apache.velocity.tools.config.InvalidScope;
    import org.apache.velocity.tools.config.ValidScope;
    
    @DefaultKey("strings")
    @ValidScope({"application","request","session"})
    public class StringsTools {
    
        /**
         * 判断字符串是否为空
         * @param str
         * @return
         */
        public boolean isEmpty(String str){
            if(str==null || "".equals(str)){
                return true ;
            }
            return false ;
        }
    
        /**
         * 生成一个指定位数的随机字符串
         * @param count
         * @return
         */
        public String randomNumeric(int count){
            return RandomStringUtils.randomNumeric(count) ;
        }
    }
    

    @DefaultKey : 用于指定默认的key
    @ValidScope : 用于指定可用的作用范围

    2、配置工具类

    <toolbox scope="application">
        <tool key="strings" class="com.kk.tools.StringsTools"  />
    </toolbox>
    

    3、使用工具类

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>Title</title>
    </head>
    <body>
    判断字符串是否为空   :   $strings.isEmpty("") <br>
    随机生成数字字符串   :   $strings.randomNumeric(6);
    </body>
    </html>
    

    4、编写Serlvet

    public class StringsToolServlet extends HttpServlet {
        protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
            doGet(request, response);
        }
    
        protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
            response.setCharacterEncoding("utf-8");
            request.getRequestDispatcher("/vms/tool-strings.vm").forward(request,response);
        }
    }
    

    其实直接访问就可以, 但是我们模板中有中文, 需要在serlvet中设置响应数据的字符集 , 否则会有乱码

    五、★springmvc整合velocity(页面静态化)

    我们之前已经在Servlet中使用velocity作为我们的视图展示数据 , 但是在开发过程中我们一般会使用框架来进行web开发, 提高我们的开发效率 , 所以下面我们来说一说在SpringMVC框架中如何使用Velocity作为视图展示数据

    1、步骤分析

    在SpringMVC中使用Velocity非常简单 , 主要有以下步骤

    1. 搭建springmvc开发环境
    2. 引入velocity依赖
    3. 配置Velocity开发环境
    4. 编写Velocity模板
    5. 编写springmvc控制器

    2、具体步骤

    2-1、搭建springmvc开发环境

    2-1-1、添加依赖

    <dependencies>
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-context</artifactId>
            <version>5.2.5.RELEASE</version>
        </dependency>
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-web</artifactId>
            <version>5.2.5.RELEASE</version>
        </dependency>
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-webmvc</artifactId>
            <version>5.2.5.RELEASE</version>
        </dependency>
    
        <dependency>
            <groupId>junit</groupId>
            <artifactId>junit</artifactId>
            <version>4.12</version>
            <scope>test</scope>
        </dependency>
    
        <dependency>
            <groupId>org.apache.tomcat</groupId>
            <artifactId>tomcat-api</artifactId>
            <version>7.0.37</version>
            <scope>provided</scope>
        </dependency>
    </dependencies>
    
    <build>
        <plugins>
            <plugin>
                <groupId>org.apache.maven.plugins</groupId>
                <artifactId>maven-compiler-plugin</artifactId>
                <version>3.8.1</version>
                <configuration>
                    <source>8</source>
                    <target>8</target>
                    <encoding>utf-8</encoding>
                </configuration>
            </plugin>
            <plugin>
                <groupId>org.apache.tomcat.maven</groupId>
                <artifactId>tomcat7-maven-plugin</artifactId>
                <version>2.2</version>
                <configuration>
                    <path>/</path>
                    <port>8080</port>
                    <uriEncoding>utf-8</uriEncoding>
                </configuration>
            </plugin>
        </plugins>
    </build>
    

    2-1-2、配置web.xml配置

    <filter>
        <filter-name>characterEncodingFilter</filter-name>
        <filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class>
        <init-param>
            <param-name>encoding</param-name>
            <param-value>UTF-8</param-value>
        </init-param>
        <init-param>
            <param-name>forceRequestEncoding</param-name>
            <param-value>true</param-value>
        </init-param>
        <init-param>
            <param-name>forceResponseEncoding</param-name>
            <param-value>true</param-value>
        </init-param>
    </filter>
    <filter-mapping>
        <filter-name>characterEncodingFilter</filter-name>
        <url-pattern>/*</url-pattern>
    </filter-mapping>
    
    
    <servlet>
        <servlet-name>dispatcherServlet</servlet-name>
        <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
        <init-param>
            <param-name>contextConfigLocation</param-name>
            <param-value>classpath:springmvc.xml</param-value>
        </init-param>
    
        <load-on-startup>1</load-on-startup>
    </servlet>
    <servlet-mapping>
        <servlet-name>dispatcherServlet</servlet-name>
        <url-pattern>/</url-pattern>
    </servlet-mapping>
    

    2-1-3、配置springmvc.xml

    <?xml version="1.0" encoding="UTF-8"?>
    <beans xmlns="http://www.springframework.org/schema/beans"
           xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
           xmlns:context="http://www.springframework.org/schema/context"
           xmlns:mvc="http://www.springframework.org/schema/mvc"
           xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd http://www.springframework.org/schema/context https://www.springframework.org/schema/context/spring-context.xsd http://www.springframework.org/schema/mvc https://www.springframework.org/schema/mvc/spring-mvc.xsd">
    
        <!--开启组件扫描-->
        <context:component-scan base-package="com.kk"></context:component-scan>
    
        <!--开启注解驱动-->
        <mvc:annotation-driven></mvc:annotation-driven>
    </beans>
    
    2-2、SpringMVC整合Velocity

    2-2-1、添加依赖

    <dependency>
        <groupId>org.apache.velocity</groupId>
        <artifactId>velocity-engine-core</artifactId>
        <version>2.2</version>
    </dependency>
    <dependency>
        <groupId>org.apache.velocity.tools</groupId>
        <artifactId>velocity-tools-generic</artifactId>
        <version>3.0</version>
    </dependency>
    <dependency>
        <groupId>org.apache.velocity.tools</groupId>
        <artifactId>velocity-tools-view</artifactId>
        <version>3.0</version>
    </dependency>
    

    2-2-2、引入Tools配置文件:在/WEB-INF/下创建并编写tools.xml配置文件

    <?xml version="1.0" encoding="UTF-8"?>
    <tools>
        <toolbox scope="application">
            <tool key="date" class="org.apache.velocity.tools.generic.DateTool" format="yyyy-MM-dd"></tool>
            <tool key="number" class="org.apache.velocity.tools.generic.NumberTool" />
            <tool key="math" class="org.apache.velocity.tools.generic.MathTool" />
        </toolbox>
    </tools>
    

    这个需要根据项目中使用的工具自己配置, 目前入门案例我们简单配置几个即可

    2-2-3、配置web.xml配置:在web.xml中配置VelocityViewServlet

    <servlet>
        <servlet-name>velocity</servlet-name>
        <servlet-class>org.apache.velocity.tools.view.VelocityViewServlet</servlet-class>
        <init-param>
            <param-name>org.apache.velocity.toolbox</param-name>
            <param-value>/WEB-INF/tools.xml</param-value>
        </init-param>
    </servlet>
    
    <servlet-mapping>
        <servlet-name>velocity</servlet-name>
        <url-pattern>*.vm</url-pattern>
    </servlet-mapping>
    

    2-2-4、配置视图解析器:因为我们现在使用velocity充当SpringMVC的视图解析器 , 所以需要配置视图解析器, 指定视图模板文件的位置及扩展名

    <bean id="internalResourceViewResolver" class="org.springframework.web.servlet.view.InternalResourceViewResolver">
        <property name="prefix" value="/vms/"></property>
        <property name="suffix" value=".vm"></property>
    </bean>
    
    2-3、编写Velocity模板:在/vms/目录下创建user-list.vm模板文件 , 用于展示列表数据
    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>Title</title>
    </head>
    <body>
    
    <table>
        <tr>
            <td>编号</td>
            <td>姓名</td> 
        </tr>
    
        #foreach($user in $userList)
            <tr>
                <td>$math.add($foreach.index,1)</td>
                <td>$user.name</td>
            </tr>
        #end
    
    </table>
    
    </body>
    </html>
    
    2-4、创建实体类
    public class User {
    
        private String name ;
        private Integer age ;
        private String sex ;
    }
    
    2-5、编写springmvc控制器
    @Controller
    @RequestMapping(path = "/user")
    public class UserController {
    
        @RequestMapping(path = "/list")
        public String list(Model model){
            List<User> userList = new ArrayList<User>();
            userList.add(new User("吕布",38,"man"));
            userList.add(new User("貂蝉",16,"woman"));
            userList.add(new User("刘备",28,"man"));
    
            model.addAttribute("userList",userList);
            return "user-list";
        }
    }
    

    因为我们配置了SpringMVC的视图解析器 , 所以控制方法返回视图名称字符串即可, 视图解析器会自动拼接完整视图路径 , 展示数据

    2-6、访问测试:http://localhost:8080/user/list

    六、综合案例

    SSM+Velocity来实现用户数据增删改查

    相关文章

      网友评论

          本文标题:C-Velocity(模板引擎) --- B版(官方API--工

          本文链接:https://www.haomeiwen.com/subject/qzefsltx.html