现在很多新闻网站的内容页都是html格式的,把内容页生成静态的html页,这样的好处是打开内容页速度快,且利于搜索引擎的收录。
我这个是struts + hibernate 框架的新闻系统,这是生成内容页的一个javabean。
public boolean SetHtml(int newsID, HttpServletRequest request) {
try {
//读取文章元素
NewsBean nb = new NewsBean();
NewsObj obj = nb.getNews(newsID);
//读取模板
String filePath = request.getContextPath() + "//templates//content.html";
String strTemplateContent;
FileInputStream fileinputstream = new FileInputStream(filePath);//读取模块文件
int lenght = fileinputstream.available();
byte bytes[] = new byte[lenght];
fileinputstream.read(bytes);
fileinputstream.close();
strTemplateContent = new String(bytes);
//获取栏目名称
ClassBean cb = new ClassBean();
ClassObj cobj = cb.getClass(obj.getNews_Class());
String ClassName = cobj.getClass_Name();
//替换
strTemplateContent = strTemplateContent.replace("$title$", obj.getNews_Title()); //标题
strTemplateContent = strTemplateContent.replace("$class$", ClassName); //栏目
strTemplateContent = strTemplateContent.replace("$time$", obj.getNews_AddTime().toString()); //发表时间
strTemplateContent = strTemplateContent.replace("$content$", obj.getNews_Content()); //新闻内容
strTemplateContent = strTemplateContent.replace("$from$", obj.getNews_From()); //文章来源
strTemplateContent = strTemplateContent.replace("$Writer$", obj.getNews_Writer()); //作者
strTemplateContent = strTemplateContent.replace("$id$", obj.getNews_Writer()); //新闻ID
//生成文件路径(html/2008-04/20/文件名.html)
String saveFilePath = request.getContextPath() + "//html//" + (1900 + obj.getNews_AddTime().getYear()) + "-" + (1 + obj.getNews_AddTime().getMonth()) + "//" + obj.getNews_AddTime().getDate();
File newsDir = new File(saveFilePath);
if (!newsDir.exists()) {
newsDir.mkdirs();
}
saveFilePath += "//" + obj.getNews_FilesName() + ".html";
//输出生成
FileOutputStream fileoutputstream = new FileOutputStream(saveFilePath); //建立文件输出流
byte tag_bytes[] = strTemplateContent.getBytes();
fileoutputstream.write(tag_bytes, 0, tag_bytes.length);
fileoutputstream.close();
} catch (Exception e) {
return false;
}
return true;
}