freemarker生成html静态页面实例

阿超 发表于 2009-08-29 13:00 | 来源: | 阅读 843 次

在原来web的例子中修改下java类和xml配置就可以了

原来的例子:http://javadou.com/freemarker-how-to-use-135/

BuildHTML.java

package example;
import java.io.*;
import java.util.*;
import javax.servlet.ServletException;
import javax.servlet.http.*;
import freemarker.template.*;
public class BuildHTML extends HttpServlet{
  private Configuration cfg;

  public void init()

  {   
//初始化FreeMarker配置        
 //创建一个Configuration实例        
cfg = new Configuration();        
//设置FreeMarker的模版文件位置   
cfg.setServletContextForTemplateLoading(getServletContext(),"templates");

  }
public void doGet(HttpServletRequest request,HttpServletResponse response) throws ServletException,IOException
  {   
//建立数据模型    Map root = new HashMap();   
//放入对应数据key value    root.put("user","zdz");   
//取得模版文件    Template t =cfg.getTemplate("hello.ftl");   
 //开始准备生成输出,输出到文件中    File file = new File(getServletContext().getRealPath("/") + "/hello.html");         if (!file.exists())             file.createNewFile();         Writer out = new FileWriter(file);    //合并数据模型和模版,并将结果输出到out中    try    {     t.process(root,out);// 用模板来开发servlet可以只在代码里面加入动态的数据    }    catch(TemplateException e)    {     throw new ServletException("处理Template模版中出现错误", e);    }

  }

  }

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>Hello</servlet-name>    <servlet-class>example.Hello</servlet-class>

  </servlet>

  <servlet-mapping>    <servlet-name>Hello</servlet-name>    <url-pattern>*.do</url-pattern>

  </servlet-mapping>

  <servlet>    <servlet-name>BuildHTML</servlet-name>    <servlet-class>example.BuildHTML</servlet-class>

  </servlet>

  <servlet-mapping>    <servlet-name>BuildHTML</servlet-name>    <url-pattern>*.b</url-pattern>

  </servlet-mapping>

  <welcome-file-list>    <welcome-file>index.html</welcome-file>

  </welcome-file-list>

  </web-app>

========================

打开ie输入http://localhost:8080/testFM/zdz.b

则在D:\Tomcat 5.5\webapps\testFM目录下生成了hello.html

效果跟http://localhost:8080/testFM/hello.do 一样,以后就可以直接访问这个html页面了,更新内容只要执行下xxx.b就可以了。

喜欢Java豆技术站点的文章,那就通过 RSS Feed 功能订阅阅读吧!

我要评论

*

* 绝不会泄露



返回首页 | 关于我们 | 联系我们 | 广告合作 | 网站地图 | 友情链接 | 版权声明 | 模板设计