生成静态页面 - 内容发布系统的开发

生成静态页面一般来说都是做好静态页面的模板,然后从数据源读取数据,生成html代码块替换模板中的标签,然后生成静态文件。比如文章页面模板部分如下:
< table  border ="1"  style ="BORDER-COLLAPSE: collapse"  width ="100%"  cellpadding ="2"  cellspacing ="2" >
< tr >
< td >
< href ="(#ArticleUrl#)" > (#Title#) </ a >
< br > 作者(#Author#) 时间2006-3-24 13:38:00
</ td >
</ tr >
< tr >
< td >
摘要:(#Description#)
</ td >
</ tr >
< tr >
< td >
(#Content#)
</ td >
</ tr >
</ table >

  我们可以用如下的方法读取该模板的内容
 

///   <summary>
///  读取文件内容
///   </summary>
///   <param name="strFilePath"> 文件路径 </param>
///   <returns> 文件内容字符串 </returns>
public   string  ReadFile( string  strFilePath,  string  strEncodingName)
{
string  strFile  =   string .Empty;
StreamReader sr 
=   new  StreamReader(strFilePath, System.Text.UnicodeEncoding.GetEncoding(strEncodingName));
try

strFile 
=  sr.ReadToEnd();
}
catch (Exception e)
{
}
finally
{
sr.Close();
}
return  strFile;
}


   假设返回的字符串是strTemplate,从数据库中读取的文章标题为strTitle,作者为strAuthro,发布时间为 strPostTime,描述为strDescription,内容为strContent,我们就可以用string的Replace方法把标签替换为 实际要显示的内容了

strArticle  =  strTemplate.Replace( " (#Title#) " , strTitle);
strArticle 
=  strArticle.Replace( " (#Author#) " , strAuthor);
    ……………………………………

  这样,strArticle就是要显示页面的html代码了,再用如下的方法写入文件

///   <summary>
///  写Html文件
///   </summary>
///   <param name="strHtml"> 写入的字符串 </param>
///   <param name="strDestinationFilePath"> 目的文件路径 </param>
public   void  WriteFile( string  strHtml,  string  strDestinationFilePath,  string  strEncodingName)
{
StreamWriter sw 
=   new  StreamWriter(strDestinationFilePath,  false , System.Text.UnicodeEncoding.GetEncoding(strEncodingName));
try
{
sw.Write(strHtml);
sw.Flush();
}
catch (Exception e)
{
strErrorMessage 
=  e.Message.ToString();
}
finally
{
sw.Close();
}
}


  这里要注意的是Replace方法有时候替换会失效,比如<a href="http://(#UserID#).it.com.cn">one</a>这里的(#UserID#)不能用Replace方法替换,可以这样来替换
strArticle = Regex.Replace(Article, "//(#UserID#//)", strUserID);
  现在,生成静态文件的方法我们会了,再来看看一些个性化技巧,如何给用户提供不同风格的各种页面。
   现在一般是通过div+css的方法给每个用户提供不同风格的页面。也就是说每个用户页面的html代码结构是一样的,只是外部css不一样,这样在写 页面的时候,我们可以把基本的html代码硬编码到我们的程序中,减少了复杂度。css可以很好的控制页面布局,实现起来很方便。这种方法中,所有风格的 同一页面模板只有一个,一个风格对应一个css文件。这样,可以满足一般的需求了,很多的blog都是采用这种方法来实现,比如blogcn, douban。
  但是,这种方法也有个缺陷,因为html代码是硬编码到后台代码中,所有风格的同一页面模板只有一个,所以页面的个性化也受到 了一定限制。比如我想让一个风格的文章列表用表格形式,另一个采用其他方式,就无法实现了,因为我们已经把具体内容写在后台代码中了,只是引用的css文 件不同。只要我们稍加改进,就完全可以随心所欲定制页面了,我的方法如下:
  每个风格一套模板,一个css。比如文章页面的另一个风格模板如下:

< div >
< href ="(#ArticleUrl#)" > (#Title#) </ a >
< br > 作者(#Author#) 时间2006-3-24 13:38:00
< hr >
摘要:(#Description#)
< br > (#Content#)
< div >

   同样,我们也可以用上面替代的方法生成页面,只是每次要根据用户所选择的模板来选择不同的模板文件,而不是所有的用户选择同一个。看到这里,你可能会 问,那要是列表怎么办?以前是把列表的html代码直接写在后台代码中,现在呢?遇到这样的情况,我们可以做下面这样的模板。

< table >
<!--  ArticlesList Start  -->
<!--  Article (#ArticleID#) Start  -->
< tr >
< td  height ="20" ></ td >
</ tr >
< tr >
< td >
< table  border ="1"  style ="BORDER-COLLAPSE: collapse"  width ="100%"  cellpadding ="2"  cellspacing ="2"  ID ="Table2" >
< tr >
< td >
< href ="(#ArticleUrl#)" > (#Title#) </ a >
</ td >
</ tr >
< tr >
< td >
摘要:(#Description#)
</ td >
</ tr >
< tr >
< td >
发表于(#ReleaseTime#)
&nbsp; | &nbsp; 评论((#CommentCount#)) &nbsp; | &nbsp; 访问((#VisitCount#))
</ td >
</ tr >
</ table >
</ td >
</ tr >
<!--  Article (#ArticleID#) End  -->
<!--  ArticlesList End  -->
</ table >

   上面的模板中<!-- Article (#ArticleID#) Start -->和<!-- Article (#ArticleID#) End -->之间的内容就是文章列表中一个文章的代码,我们只需要用正则表达式把这部分找出来,替换标签就得到了一个列表中一个文章的html代码,把所 有文章的代码连起来就得到了文章列表的代码,再让得到的代码替换模板中<!-- ArticlesList Start -->和<!-- ArticlesList End -->的内容就得到了最终要写入页面的代码。虽然比以前div+css的方式多了些步骤,但是,这样确实有效可行。大家也许会发现,上面的模板也为 某些更新页面而不需要读数据库提供了基础,比如我要从文章列表中删除ID为100的文章,我们只要删除<!-- Article 100 Start -->和<!-- Article 100 End -->之间的内容就可以了,根本不需要再读数据库。但是,这样也会带来隐患,假如某次文件操作失败,那就永远是失败,不能跟数据库的内容同步,当然 你可以通过提供其他功能来解决这个问题。
  既然是为了性能,我们把页面发布成静态,那我们不如再进一步,看看怎样提高写静态页面的性能。
  1.提取所有页面的公共部分,放外部文件进行引用。
   比如所有页面的导航部分是相同的,这些部分经常要根据用户的操作进行更新,如果把它完全写在每个页面中,更新起来代价是很大的,必须重写每个页面。我们 可以把这些内容外挂到js中,更新这些内容的时候,更新相应的js文件就可以了,一次更新,整站更新。这里,要注意的是要对js的特殊字符要进行转义,比 如;'"等特殊字符要在前面加上/进行转义。
  2.局部更新,而不是整体更新
  我们可以用<!-- ArticlesList Start -->和<!-- ArticlesList End -->这样的标记把文章列表标记出来,更新文章页面的时候,我们只需要生成文章列表html代码,代替原页面(非模板)这两个标记之间的内容就可以 了。这样,能大量减少读数据库的次数,性能自然也提高不少。在不同内容越多的页面,性能优势越明显。
  3.使用分层树结构存放文件
  这个其实是对读取性能的优化了。我们不要把大量的文件都生成在同一个根目录下,这样服务器遍历文件就会影响性能。我们可以使用分层树结构来生成文件,比如按年/月/日的形式组织文件目录。
   综合有目的性的使用以上方法可以提高发布系统的性能,也能使用户界面最大限度地个性化。有时,我们可以采用静态和动态结合的方法提高系统性能,比如文章 列表第一页生成静态,后面的采用动态方式。总之,对访问频率越高的页面生成静态越有优势,更新频率越高的页面动态方式越有优势,所以我们要均衡两者,有的 放矢的选择。

 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
明博静态新闻文章发布系统源码 管理后台:/Admin/index.aspx 默认管理账号密码为51aspx 文件说明: Admin/DefineType.aspx 定义文章类型-----定义文章或新闻的类别。 Admin/DefineExample.aspx 定义文章模板-----可以定义多个模版,其替换标志在 FileSubmit.aspx.cs 第 53行起。 Admin/InsertExample.aspx 一个增加模板的单独界面 Admin/FileManage.aspx 文章列表管理-----可以对文章进行删除和基本信息修改,这里的增加和修改不能对静态Html文件操作。 Admin/FileSubmit.aspx 增加文章 --------可以选择定义的模版来添加文章。 Files/ShowFileList.aspx 显示已经添加的文章列表 -----上面几个是后台管理操作的,这个是前台供访客浏览的界面。 ShowFileItems.aspx 把部分信息的标题显示在其它页面 管理主页 使用方法: 显示某类新闻的列表 就是说,你要知道该类别ID,在管理里面的[定义类别]列表里而已查到 /Files/ShowFileList.aspx?TypeID=1 把新闻显示在主页或其它页面上 <script type="text/javascript" src="/Files/ShowFileItems.aspx?Num=8&TypeID=1&ShowTime=YES"></script> Num=数字 你要显示的信息条数 TypeID=数字 你要显示信息类别的ID, ID可以在[定义类别]列表里而已查到 ShowTime=YES 信息后面显示时间,NO或空则后面不显示时间 定义页头和页尾,就是显示自己的菜单和下面页脚 修改/JS/jsMainMenu.js中页头由ShowTitle() ShowBanner() ShowMenu()三个函数组成,你用几个函数都可以,如果用一个ShowTitle(),其他的定义为空函数OK了。页脚是Showbottom()。 定义模板 ---你的模板里面可以定义如下几个字符串,可以参考下面的模板分析 T_TITLE 标题 T_TIME 日期 T_KeyWords 关键字 T_Author 作者 T_Editor 编辑人 T_CONTENT 文章内容 4 类别ID Jim 配置后请修改web.config中Access数据库的物理路径 作者:Minbel
网站演示:http://qywz.wrzc.net 界面预览:http://down.wrzc.net/qywzwrzcnet.jpg 软件介绍:公司网站管理系统商业版源码下载,中文版免费企业网站管理系统,生成静态html文件的漂亮蓝色风格网页模板免费下载,企业网站模板,公司网站模板下载,公司网页模板,后台地址/admin/Login.asp,后台帐号admin密码为admin 网软志成企业网站管理系统V2030生成HTML静态页面版新增功能: 1.全站使用DIV+CSS排版,极大提升网站速度,更有利于搜索引擎收录数量和网店排名; 2.能在后台自动生成前台静态html网页,提升网站访问速度,兼容目前主流浏览器,提高搜索引擎收录数量和网店排名; 3.全站使用UTF-8国际编码,不管在国内的中文环境还是在国外的英文环境,网站都能正常显示; 4.使用了全新的产品图片浏览效果; 5.新增企业视频广告功能; 6.前后台进行了全新的优化和美化,更加适合当前主流的高分辨率显示; 7.更新了在线资讯功能,除了QQ增加了MSN,淘宝旺旺,同时都可在后台管理; 8.网站搜索功能进行了整合; 9.首页模板布局做了全新的调整; 10.新增企业地址导航地图; 11.后台新增网站推广功能,更有利于企业网站的排名和收录; 12.对全站进行了SEO优化; 13.修复了以往发现的BUG. 网软志成中英文双语企业网站管理系统,生成静态html文件的企业门户网站系统免费下载,后台自动生成前台静态html网页,公司网站主页模板,企业网站首页模板下载,asp生成html的,网软志成企业网站管理系统生成html正式版源码下载,有宣传,介绍,展示,推广,销售公司企业的产品与服务,开展企业网上电子商务业务的,实现营利,是整站系统设计功能的最终目标.可自助建立栏目菜单,可无限制扩展栏目分类的企业网站后台管理系统,咨询服务公司,中介公司,教育公司有限公司,公司注册公司,企业认证,商标专利公司整站代码,金融,保险,中介公司网站系统,维修安装,装饰公司网站asp版本,餐饮公司,展览公司,翻译公司网页模版,会计公司,软件公司网站生成html静态全站程序,公司网站自助建站程序,任意设置的会员级别和浏览权限精确到每条记录,这对于希望不同内容针对不查看对象开放来讲,无疑是最佳解决方案。企业网站智能建站系统,独具创意的其他信息无限扩展栏,对于希望发布固定栏目无法归类的其他信息,将是非常棒的途径。公司门户网站系统,公司网站内容管理系统商业版,完善的网站子模块,如企业简历,企业文化,企业新闻,业内资讯,产品展示,下载中心,企业荣誉,营销网络,人才招聘,客户留言,会员中心,充分考虑了公司,企业中英文网站管理系统的通用需求.网软志成提供的企业网站系统是采用全后台管理方式,后台功能齐全,使用维护方便.asp生成html版本,以及php生成html照明工业公司网站管理系统中文版,企业网站管理系统简体版,utf-8国际通用编码的企业网站整站程序,让全世界浏览网站的用户畅通无阻,交通运输企业整站程序,安防公司免费三语版整站程序,包装印刷公司,环保设备,中英文模具加工公司网站繁体商业版下载,服装公司,服饰公司网站免费下载,礼品公司,中文,英文适用的家居用品公司,电子公司网站模板,汽车公司网站系统,最专业的软件公司,多年开发经验,全国知名美工制作模板,标准化设计的企业门户网站建站管理系统,完全免费的灯饰企业公司网站源码,安防公司网站模板,生成html的包装公司网站模板,印刷厂网站源码,机床公司网站模板,家居装饰公司网站建设,网软志成企业网站管理系统生成html中文正式版源码下载,化妆品网站模板公司网站源码,礼品公司网站模板,DIV+CSS排版的手机公司企业网站管理系统,通讯公司,运动网站模板下载,家电公司网站模板正式版,数码公司网站源码完整版,网络公司网站模板下载,玩具公司网站模板,食品企业公司网站模板下载,办公设置公司网站,冶金矿产企业网站模板无限制版,纺织公司网站模板,农业林业公司网站模板,公司管理系统,政府网站管理系统,公司企业网站管理系统,电脑公司系统下载,个人网站系统,企业网站系统官方网站,asp网站管理系统,asp网站系统,网站生成系统,企业网站内容管理系统源码,网站源码下载无论是生产,销售,还是服务型的大中小型公司,企业的网站管理人员只要会打字,就会建起一个专业的公司,企业网站,随时管理网站内容.当企业信息介绍内容过长,需要多次滚屏时,可以考虑对内容做内分页处理。流量统计信息可以清零重置。信息暂存功能,即对于某些临时不需要发布内容暂存起来,不用删除,以后重新开放即可。所有前台提交表单防刷新处理,有效过滤垃圾信息提交。此系统是基于asp+mssql技术开发的企业级电子商务平台,运行安全,稳定,快速,全自动化、全智能的在线方式管理、维护、更新的企业网站管理系统。提供下载的整站,程序源码,功能完全,欢迎大家下载使用.企业网站管理系统功能将更加完全,真正的能为大家在建设公司,企业网站中带来安全,稳定,高效。 免费网站模板,蓝色公司网站模板,商业网站模板,asp网站模板,公司网站管理系统,网站管理系统,网站系统,企业网站管理系统,免费企业网站模板,企业静态网站模板,中文企业网站模板,优秀企业网站模板,中小企业网站模板,企业网站设计模板,asp企业网站模板,asp企业网站模板,简单企业网站模板,韩国企业网站模板,完善的网站子模块,如企业简历,企业文化,企业新闻,业内资讯,产品展示,下载中心,企业荣誉,营销网络,人才招聘,客户留言,会员中心,充分考虑了公司,企业中英文网站管理系统的通用需求.全后台管理方式,后台功能齐全,使用维护方便.无论是生产,销售,还是服务型的大中小型公司,企业的网站管理人员只要会打字,就会建起一个专业的公司,企业网站,随时管理网站内容.提供下载的整站,程序源码,功能完全,欢迎大家下载使用.企业网站管理系统功能将更加完全,真正的能为大家在建设公司,企业网站中带来安全,稳定,高效。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值