博客
关于我
商城项目中使用Freemarker生成静态页面html
阅读量:346 次
发布时间:2019-03-04

本文共 2406 字,大约阅读时间需要 8 分钟。

在商城项目中,通过技术手段实现静态页面生成,可以有效提升网站性能和用户体验。本文将介绍如何利用Freemarker模板引擎和消息队列技术,实现商品上架后的静态页面生成机制。

一、静态模板制作

原有的产品详情页面通常是JSP形式,改写为静态HTML模板后,需要注意以下几点:

  • 模板结构优化:去除不必要的C标签,将动态标签替换为Freemarker模板标签。例如,列表循环可以用<#list persons as person>实现。
  • 模板引入:通过<#include>标签引入公共模块,例如导入 footer.html。
  • 字符编码设置:在模板顶部添加<meta charset="UTF-8">,确保页面字符集一致。
  • 二、配置Freemarker模板引擎

    在项目中添加必要的Freemarker配置文件freemarker.xml

    三、消息队列监听

    为了实现动态静态页面生成,需要设置消息队列监听:

  • JMS配置
  • public class CustomMessageListener implements MessageListener {
    @Autowired
    private StaticPageService staticPageService;
    @Override
    public void onMessage(Message message) {
    try {
    String productId = ((ActiveMQTextMessage) message).getText();
    // 查询商品详情
    Product product = cmsService.selectProductById(productId);
    // 查询库存信息
    List
    skus = cmsService.selectSkuListByProductId(productId);
    Set
    colors = new HashSet<>();
    for (Sku sku : skus) {
    colors.add(sku.getColor());
    }
    Map
    root = new HashMap<>();
    root.put("product", product);
    root.put("skus", skus);
    root.put("colors", colors);
    staticPageService.productStaticPage(root, productId);
    } catch (JMSException e) {
    e.printStackTrace();
    }
    }
    }
    1. 消息监听配置
    2. 四、生成静态页面

      静态页面生成的具体实现逻辑:

      public void productStaticPage(Map
      root, String id) {
      String path = getPath("/html/product/" + id + ".html");
      File f = new File(path);
      File parentFile = f.getParentFile();
      if (!parentFile.exists()) {
      parentFile.mkdirs();
      }
      try {
      Template template = conf.getTemplate("productDetail.html");
      Writer out = new OutputStreamWriter(new FileOutputStream(f), "UTF-8");
      template.process(root, out);
      } catch (Exception e) {
      e.printStackTrace();
      } finally {
      try {
      if (null != out) {
      out.close();
      }
      } catch (IOException e) {
      e.printStackTrace();
      }
      }
      }

      五、链接优化

      在产品列表页面,修改商品链接:

      ...

      六、项目验证

      完成上述配置后,通过浏览器访问商城页面,验证静态页面生成效果。

      通过以上步骤,可以实现商品上架后自动生成静态HTML页面,提升网站性能表现。

    转载地址:http://qnse.baihongyu.com/

    你可能感兴趣的文章
    NIFI大数据进阶_NIFI的模板和组的使用-介绍和实际操作_创建组_嵌套组_模板创建下载_导入---大数据之Nifi工作笔记0022
    查看>>
    NIFI大数据进阶_NIFI监控的强大功能介绍_处理器面板_进程组面板_summary监控_data_provenance事件源---大数据之Nifi工作笔记0025
    查看>>
    NIFI大数据进阶_内嵌ZK模式集群1_搭建过程说明---大数据之Nifi工作笔记0015
    查看>>
    NIFI大数据进阶_外部ZK模式集群1_实际操作搭建NIFI外部ZK模式集群---大数据之Nifi工作笔记0017
    查看>>
    NIFI大数据进阶_离线同步MySql数据到HDFS_01_实际操作---大数据之Nifi工作笔记0029
    查看>>
    NIFI大数据进阶_离线同步MySql数据到HDFS_02_实际操作_splitjson处理器_puthdfs处理器_querydatabasetable处理器---大数据之Nifi工作笔记0030
    查看>>
    NIFI大数据进阶_连接与关系_设置数据流负载均衡_设置背压_设置展现弯曲_介绍以及实际操作---大数据之Nifi工作笔记0027
    查看>>
    NIFI数据库同步_多表_特定表同时同步_实际操作_MySqlToMysql_可推广到其他数据库_Postgresql_Hbase_SqlServer等----大数据之Nifi工作笔记0053
    查看>>
    NIFI汉化_替换logo_二次开发_Idea编译NIFI最新源码_详细过程记录_全解析_Maven编译NIFI避坑指南001---大数据之Nifi工作笔记0068
    查看>>
    NIFI集群_内存溢出_CPU占用100%修复_GC overhead limit exceeded_NIFI: out of memory error ---大数据之Nifi工作笔记0017
    查看>>
    NIFI集群_队列Queue中数据无法清空_清除队列数据报错_无法删除queue_解决_集群中机器交替重启删除---大数据之Nifi工作笔记0061
    查看>>
    NIH发布包含10600张CT图像数据库 为AI算法测试铺路
    查看>>
    Nim教程【十二】
    查看>>
    Nim游戏
    查看>>
    NIO ByteBuffer实现原理
    查看>>
    Nio ByteBuffer组件读写指针切换原理与常用方法
    查看>>
    NIO Selector实现原理
    查看>>
    nio 中channel和buffer的基本使用
    查看>>
    NIO三大组件基础知识
    查看>>
    NIO与零拷贝和AIO
    查看>>