Java读取根据HTML模板生成HTML页面
首先,我们需要一个html模板:
- <html>
- <head>
- <title>###title###</title>
- <meta http-equiv="Content-Type" content="text/html; charset=gbk">
- </head>
- <body>
- <table width="500" border="0" align="center" cellpadding="0" cellspacing="2">
- <tr>
- <td align="center">###title###</td>
- </tr>
- <tr>
- <td align="center">###author### </td>
- </tr>
- <tr>
- <td>###content###</td>
- </tr>
- <tr>
- <td>###html###</td>
- </tr>
- </table>
- </body>
- </html>
其次:我们编写java代码实现模板读取,页面生成:
- import javax.servlet.http.HttpServletRequest;
- import java.util.List;
- import java.util.ArrayList;
- import java.util.Date;
- import java.net.URL;
- import java.net.URLConnection;
- import java.io.*;
- /**
- * Filename: JspToHtml.java <br>
- * Ttitle: jsp转换成html<br>
- * De.ion: 把动态网页转换成静态网页<br>
- * Copyright: Copyright (c) 2002-2008 BocSoft,Inc.All Rights Reserved. <br>
- * Company: BocSoft<br>
- * Author: <a href="mailto:sgicer@163.com">阿汐</a> <br>
- * Date: 2006-6-19 <br>
- * Time: 16:41:09 <br>
- * Version: 2.0.0 <br>
- */
- public class JspToHtml {
- private static String title ="标题测试";
- private static String context ="标题测试";
- private static String editer ="标题测试";
- /**
- * 根据本地模板生成静态页面
- * @param JspFile jsp路经
- * @param HtmlFile html路经
- * @return
- */
- public static boolean JspToHtmlFile(String filePath, String HtmlFile) {
- String str = "";
- long beginDate = (new Date()).getTime();
- try {
- String tempStr = "";
- FileInputStream is = new FileInputStream(filePath);//读取模块文件
- BufferedReader br = new BufferedReader(new InputStreamReader(is));
- while ((tempStr = br.readLine()) != null)
- str = str + tempStr ;
- is.close();
- } catch (IOException e) {
- e.printStackTrace();
- return false;
- }
- try {
- str = str.replaceAll("###title###",title);
- str = str.replaceAll("###content###",context);
- str = str.replaceAll("###author###",editer);//替换掉模块中相应的地方
- File f = new File(HtmlFile);
- BufferedWriter o = new BufferedWriter(new FileWriter(f));
- o.write(str);
- o.close();
- System.out.println("共用时:" + ((new Date()).getTime() - beginDate) + "ms");
- } catch (IOException e) {
- e.printStackTrace();
- return false;
- }
- return true;
- }
- /**
- * 根据url生成静态页面
- *
- * @param u 动态文件路经 如:http://www.163.com/x.jsp
- * @param path 文件存放路经如:x:\\abc\bbb.html
- * @return
- */
- public static boolean JspToHtmlByURL(String u, String path) {
- //从utl中读取html存为str
- String str = "";
- try {
- URL url = new URL(u);
- URLConnection uc = url.openConnection();
- InputStream is = uc.getInputStream();
- BufferedReader br = new BufferedReader(new InputStreamReader(is));
- while (br.ready()) {
- str += br.readLine() + "\n";
- }
- is.close();
- //写入文件
- File f = new File(path);
- BufferedWriter o = new BufferedWriter(new FileWriter(f));
- o.write(str);
- o.close();
- str = "";
- return true;
- } catch (Exception e) {
- e.printStackTrace();
- return false;
- }
- }
- /**
- * 根据url生成静态页面
- *
- * @param url 动态文件路经 如:http://www.163.com/x.jsp
- * @return d
- */
- public static StringBuffer getHtmlTextByURL(String url) {
- //从utl中读取html存为str
- StringBuffer sb = new StringBuffer();
- try {
- URL u = new URL(url);
- URLConnection uc = u.openConnection();
- InputStream is = uc.getInputStream();
- BufferedReader br = new BufferedReader(new InputStreamReader(is));
- while (br.ready()) {
- sb.append(br.readLine() + "\n");
- }
- is.close();
- return sb;
- } catch (Exception e) {
- e.printStackTrace();
- return sb;
- }
- }
- /**
- * 测试main 函数
- *
- * @param arg
- */
- public static void main(String[] arg) {
- long begin = System.currentTimeMillis();
- //循环生成10个html文件
- for (int k = 0; k < 10; k++) {
- String url = "E:\\workspace\\oa\\golatel\\utils\\Temp\\mb.htm";//模板文件地址
- String savepath = "d:/" + k + ".html";//生成文件地址
- JspToHtmlFile(url, savepath);
- }
- System.out.println("用时:" + (System.currentTimeMillis() - begin) + "ms");
- }
- }
Java读取根据HTML模板生成HTML页面的更多相关文章
- html模板生成静态页面及模板分页处理
它只让你修改页面的某一部分,当然这"某一部分"是由你来确定的.美工先做好一个页面,然后我们把这个页面当作模板(要注意的是这个模板就没必要使用EditRegion3这样的代码了,这种 ...
- 【Java】itext根据模板生成pdf(包括图片和表格)
1.导入需要的jar包:itext-asian-5.2.0.jar itextpdf-5.5.11.jar. 2.新建word文档,创建模板,将文件另存为pdf,并用Adobe Acrobat DC打 ...
- 利用模板生成html页面(NVelocity)
公司的网站需要有些新闻,每次的新闻格式都是一样的,而不想每次都查询操作,所以想把这些新闻的页面保存成静态的html,之后搜索了下就找到了这个模板引擎,当然其他的模板引擎可以的,例如:Razor,自己写 ...
- JAVA使用itext根据模板生成PDF文档
1.制作PDF模板 网址打开:https://www.pdfescape.com/open/ 我们这里先在线上把基础的内容用word文档做好,然后转成PDF模板,直接上传到网站上,这样方便点 假设我们 ...
- Java Web项目--使用JSP生成一个页面
我们使用了servlet生成了一个网页,但是可以看到使用servlet生成网页必须将网页的内容全部嵌入到Java代码当中,不是很方便.所以有没有什么办法是将Java代码嵌入到html代码中,而不是像s ...
- Java Web项目--使用Servlet生成一个页面
为了生成一个servlet对应的网页.我们需要新建一个web.xml,其中将会放置servlet的相关信息.web.xml文件放置在WebContent/WEB-INF/目录下.(我们在Eclipe中 ...
- 第四篇:java读取Excel简单模板
场景:对于经常需要导入Excel模板或数据来解析后加以应用的,使用频率非常之高,做了一个比较稳定的版本,体现在这些地方工具:org.apache.poi使用前必须了解这些:1.要解析,那肯定先判断是不 ...
- java 根据word xml模板生成word
这里用的是poi相关jar包以及freemarker插值技术实现,poi相关jar包这里不再述说 1,编辑word并保存为xml 2,把xml后缀改为ftl文件 3,前端代码 // alert(jso ...
- html-webpack-plugin插件 根据模板生成多页面
1.项目目录结构为: 2.webpack.config.js配置文件为: var htmlWebpackPlugin = require('html-webpack-plugin'); module. ...
随机推荐
- vue数组中数据变化但是视图没有更新解决方案
原文链接:http://www.cnblogs.com/sufubo/p/6906261.html#undefined 问题:在vue项目中,我更改数组中的某一条数据,直接arr[i]=newVal ...
- php判断
<?php $str = '我是张三?'; preg_match("/张三/", $str, $match); if($match) { echo ' 张三在文本中'; } ...
- shell查询MySQL并将结果写入文件中
背景 说下需求,自己搭建的一个接口开放平台,包含API文档和功能测试,部分内网地址需要修改hosts文件 准备 新建表 然后查看服务器中hosts文件 命令:cat /etc/hosts 我们要做的就 ...
- 华硕B360主板装机找不到固态硬盘启动
1.开机点按F2进入BIOS中,在security选项卡中选择secure boot menu,secure boot control按Enter选择Disable,按F10保存: 2.电脑重 ...
- IO[File_API学习]
IO流[File_API学习的使用] File_API学习的使用1.名称分隔符 / \ separatorjava下路径:\ 在Windows下的路径,在java里 \ 是转义字符.需要 \\Str ...
- 适配器 1、ArrayAdapter 2.SimpleAdapter
1.ArrayAdapter(数组适配器):用于绑定格式单一的数据.数据源:可以是集合或数组 public class MainActivity extends AppCompatActivity { ...
- Android 计算器制作 1.布局
1.activity_main.xml文件布局 <LinearLayout xmlns:android="http://schemas.android.com/apk/res/andr ...
- jdk提供的线程协调API suspend/resume wait/notify park/unpark
线程通信(如 线程执行先后顺序,获取某个线程执行的结果等)有多种方式: 文件共享 线程1 --写入--> 文件 < --读取-- 线程2 网络共享 变量共享 线程1 --写入--> ...
- Task扩展方法取消操作
/// <summary> /// 任务扩展,传入取消操作 /// </summary> public static class TaskExtensionDemo { //因 ...
- slplunk原始数据和索引数据大小比较
DB目录总大小:2468MB 所有buckets的meta信息在.bucketManifest文件里: id,path,"raw_size","event_count&q ...