电商项目总结(5)freemarker网页静态化方案

freemarker实现网页的静态化,能够提高用户的体验。通过将jsp改造成freemarker模板文件,通过调用生成一个静态化的网页html。可以将html保存到电脑的任意一个地方,在使用nginx来访问这些静态的页面。

首先://1.创建一个模板文件,放在webapp/下;

       //2.创建一个模板对象 Configuration configuration=new Configuration();

      //3.设置模板文件保存的目录

      //4.设置模板文件保存的格式utf-8

      //5.加载一个模板文件,创建一个模板对象 Template template=configuration.getTemplate(“模板文件”);

     //6.创建一个数据集 Map map=new HashMap<>();  map.put("key","value");这个key是对应模板文件如${key}

    //7.创建一个Writer对象指定输出的文件路径和文件名 Writer out=new FileWriter(“本地计算机的绝对路径/文件名(格式)”),这个文件是自动创建的,不用手动创建

   //8.使用模板对象进行加载 template.procee(map,out);

在spring容器中配置了freemarker,可以将以下代码代替2,3,4步骤

Configuration configuration=freemarkerConfiguration.getConfiguration();

freemarker的模板文件和jsp用法差不太多,有几个要注意的

1)在jsp中循环遍历结果集是使用

    在freemarker的模板文件中使用<#list  cartList as lt>

2)在jsp中引入其他的jsp文件使用 <%include file="xxx.jsp" %>

  在freemarker中是使用 <#inclue "xxx.jsp"/>

其他的都差不太多,有写的错的博友们给指出来。

在该项目中,jsp是动态的展示页面,而html是静态页面,这样会增加用户的体验性,在访问商品详情页面,点击商品,将会出现新商品的详情页面,这个商品的详情页面是提前加载好的html,当用户查看商品详情,通过nginx将访问到资源。那怎么一添加商品就生成静态页面呢?通过activemq消息中间件原理实现消息的监听,当监听到商品添加的消息后,立马查询数据库,生成一个静态的页面html。

你可能感兴趣的:(电商项目总结(5)freemarker网页静态化方案)