zoukankan      html  css  js  c++  java
  • vert.x学习(四),使用模板解析器ClassLoaderTemplateResolver

    在vert.x中使用模板解析,可以为我们带来很多方便。我这里学习了一下ClassLoaderTemplateResolver的简单使用。这次工程配置与上篇一样,不需要做任何多的配置。直接编写代码就可以了。

    编写HelloThymeleafResolver.java

    package com.javafm.vertx.helloworld;
    
    import io.vertx.core.Vertx;
    import io.vertx.core.http.HttpServer;
    import io.vertx.ext.web.Router;
    import io.vertx.ext.web.templ.ThymeleafTemplateEngine;
    import org.thymeleaf.templateresolver.ClassLoaderTemplateResolver;
    
    /**
     * Created by lemontea <36634584@qq.com> on 16-12-20.
     */
    public class HelloThymeleafResolver {
        public static void main(String[] args) {
            Vertx vertx = Vertx.vertx();
            HttpServer httpServer = vertx.createHttpServer();
            Router router = Router.router(vertx);
            ThymeleafTemplateEngine templateEngine = ThymeleafTemplateEngine.create();
            // 定时模板解析器,表示从类加载路径下找模板
            ClassLoaderTemplateResolver templateResolver = new ClassLoaderTemplateResolver();
            // 设置模板的前缀,我们设置的是templates目录
            templateResolver.setPrefix("templates");
            // 设置后缀为.html文件
            templateResolver.setSuffix(".html");
            templateResolver.setTemplateMode("HTML5");
            templateEngine.getThymeleafTemplateEngine().setTemplateResolver(templateResolver);
            router.route("/hello").handler(routingContext -> {
                routingContext.put("msg", "Hello ClassLoaderTemplateResolver!");
                // 这里render的第二个参数,就是模板文件名称,由于在Resolver里面设置了前缀和后缀这里就可以简写了
                templateEngine.render(routingContext, "/hello", res -> {
                    if (res.succeeded()) {
                        routingContext.response().putHeader("Content-Type", "text/html").end(res.result());
                    } else {
                        routingContext.fail(res.cause());
                    }
                });
    
            });
            httpServer.requestHandler(router::accept).listen(8080);
        }
    }

    模板文件继续沿用之前的resources/templates/hello.html,现在右键启动http服务,在浏览器中查看

    在附一张IDEA工程结构截图

    源代码可以从github clone:https://github.com/tjz101/vertxworld

    原创文章,转载请注明出处。

  • 相关阅读:
    linux配置显示git分支名
    tensorrt int8量化原理几点问题记录
    cuda Global Memory Access
    cuda shared memory bank conflict
    一种简单的死锁检测算法
    n = 5x+2y+z,程序优化:unroll loop
    c++ detect && solve integer overflow
    Tensorpack.MultiProcessPrefetchData改进,实现高效的数据流水线
    tensorflow layout optimizer && conv autotune
    python 产生token及token验证
  • 原文地址:https://www.cnblogs.com/tangjizhong/p/6201785.html
Copyright © 2011-2022 走看看