【收藏】利用ASP.NET技术动态生成HTML页面

【摘 要】利用如Dw-Mx这样的工具生成html格式的模板,在需要添加格式的地方加入特殊标记(如$),动态生成文件时利用代码读取此模板,然后获得前台输入的内容,添加到此模板的标记位置中,生成新文件名后写入磁盘,写入后再向数据库中写入相关数据。

asp.net动态生成html页面
    此功能适用于后台数据库功能不强的web站点,即大部分文本不是存放在数据库的记录中,而是放在html文件或者xml文件中,仅仅把索引放到数据库中,如文章标题、类别、查询关键字等。这样适合于后台没有诸如ms sql server这样的数据库支持的web站点。

  适用于新闻发布系统,比如sina、163等都是采用动态生成html页面的。

  适用于需动态定制页面的程序。比如论坛、聊天室等。可以加载定制好的html页面,来加强美观。


   思路

  1. 利用如Dw-Mx这样的工具生成html格式的模板,在需要添加格式的地方加入特殊标记(如$),动态生成文件时利用代码读取此模板,然后获得前台输入的内容,添加到此模板的标记位置中,生成新文件名后写入磁盘,写入后再向数据库中写入相关数据。

  2. 使用后台代码硬编码Html文件,可以使用HtmlTextWriter类来写html文件。

  优点

  1. 可以建立非常复杂的页面,利用包含js文件的方法,在js文件内加入document.write()方法可以在所有页面内加入如页面头,广告等内容。

  2. 静态html文件利用MS Windows2000的Index Server可以建立全文搜索引擎,利用asp.net可以以DataTable的方式得到搜索结果。而Win2000的Index服务无法查找xml文件的内容。如果包括了数据库搜索与Index索引双重查找,那么此搜索功能将非常强大。

  3. 节省服务器的负荷,请求一个静态的html文件比一个aspx文件服务器资源节省许多。

  缺点

  思路二: 如果用硬编码的方式,工作量非常大,需要非常多的html代码。调试困难。而且使用硬编码生成的html样式无法修改,如果网站更换样式,那么必须得重新编码,给后期带来巨大的工作量。

  因此这里采用的是第一种思路

  示列代码

  1.定义(template.htm)html模板页面

<html>
<head>
<title>www.webjx.com</title>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312">
</head>
<body >
<table height="100%" border="0" width="100%" cellpadding="10" cellspacing="0" bgcolor="#eeeeee" style="border:1px solid #000000">
<tr>
<td width="100%" valign="middle" align="left">
<span style="color: ;font-size: "></span>
</td>
</tr>
</table>
</body>
</html>

  2.asp.net代码:

//---------------------读html模板页面到stringbuilder对象里----

string[] format=new string[4];//定义和htmlyem标记数目一致的数组
StringBuilder htmltext=new StringBuilder();
try
{
 using (StreamReader sr = new StreamReader("存放模板页面的路径和页面名"))
 {
  String line;
  while ((line = sr.ReadLine()) != null)
  {
   htmltext.Append(line);
  }
  sr.Close();
 }
}
catch
{
 Response.Write("<Script>alert('读取文件错误')</Script>");
}

//---------------------给标记数组赋值------------

format[0]="background=/"bg.jpg/"";//背景图片
format[1]= "#990099";//字体颜色
format[2]="150px";//字体大小
format[3]= "<marquee>生成的模板html页面</marquee>";//文字说明
//----------替换htm里的标记为你想加的内容
for(int i=0;i<4;i++)
{
 htmltext.Replace("["+i+"]",format[i]);
}

//----------生成htm文件------------------――

try
{
 using(StreamWriter sw=new StreamWriter("存放路径和页面名",false,System.Text.Encoding.GetEncoding("GB2312")))
{
 sw.WriteLine(htmltext);
 sw.Flush();
 sw.Close();
}

}

catch

{

Response.Write ("The file could not be wirte:");

}

  小结

  用此方法可以方便的生成html文件。程序使用了是循环替换,因此对需替换大量元素的模板速度非常快。

 

--------------------------------------------------------------------------------
ASP.Net生成静态HTML页

环境:Microsoft .NET Framework SDK v1.1
OS:Windows Server 2003 中文版
ASP.Net生成静态HTML页
在Asp中实现的生成静态页用到的FileSystemObject对象!
在.Net中涉及此类操作的是System.IO
以下是程序代码 注:此代码非原创!参考别人代码
Code:
//生成HTML页
public static bool WriteFile(string strText,string strContent,string strAuthor)
{
string path = HttpContext.Current.Server.MapPath("/news/");
Encoding code = Encoding.GetEncoding("gb2312");
// 读取模板文件
string temp = HttpContext.Current.Server.MapPath("/news/text.html");
StreamReader sr=null;
StreamWriter sw=null;
string str="";
try
{
sr = new StreamReader(temp, code);
str = sr.ReadToEnd(); // 读取文件
}
catch(Exception exp)
{
HttpContext.Current.Response.Write(exp.Message);
HttpContext.Current.Response.End();
sr.Close();
}


string htmlfilename=DateTime.Now.ToString("yyyyMMddHHmmss")+".html";
// 替换内容
// 这时,模板文件已经读入到名称为str的变量中了
str =str.Replace("ShowArticle",strText); //模板页中的ShowArticle
str = str.Replace("biaoti",strText);
str = str.Replace("content",strContent);
str = str.Replace("author",strAuthor);
// 写文件
try
{
sw = new StreamWriter(path + htmlfilename , false, code);
sw.Write(str);
sw.Flush();
}
catch(Exception ex)
{
HttpContext.Current.Response.Write(ex.Message);
HttpContext.Current.Response.End();
}
finally
{
sw.Close();
}
return true;


此函数放在Conn.CS基类中了
在添加新闻的代码中引用 注:工程名为Hover

if(Hover.Conn.WriteFile(this.Title.Text.ToString(),this.Content.Text.ToString(),this.Author.Text.ToString()))
{
Response.Write("添加成功");
}
else
{
Response.Write("生成HTML出错!");
}


模板页Text.html代码
Code:
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN" >
<HTML>
<HEAD>
<title>ShowArticle</title>
<body>
biaoti
<br>
content<br>
author
</body>
</HTML>
biaoti
<br>
content<br>
author
</body>
</HTML>

 

提示添加成功后会出以当前时间为文件名的html文件!上面只是把传递过来的几个参数直接写入了HTML文件中,在实际应用中需要先添加数据库,然后再写入HTML文件

 

 

主要包含三个页面文件TempHtml.html(模板文件),default.aspx(上传新闻内容页面),deault.aspx.cs(后台实现代码):

新闻模板文件(TempHtml.html):

<html>
        <head>
               <title>$htmlkey[0]</title>
               <meta http-equiv="Content-Type" content="text/html; charset=gb2312">
        </head>
        <body >
               <table $htmlkey[1] height="100%" border="0" width="100%" cellpadding="10" cellspacing="0"   bgcolor="#eeeeee" style="border:1px solid #000000">
                  <tr>
                     <td width="100%" valign="middle" align="left">
       <span style="color: $htmlkey[2];font-size: $htmlkey[3]"><marquee>$htmlkey[4]</marquee></span>
      </td>
                  </tr>
               </table>
        </body>
</html>

上传新闻内容页面:default.aspx

<%@ Page Language="C#" AutoEventWireup="true" CodeFile="default.aspx.cs" Inherits="default" %>

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<html xmlns="http://www.w3.org/1999/xhtml" >
<head runat="server">
     <title>Untitled Page</title>
</head>
<body>
    <form id="Form1" method="post" runat="server">
    <asp:Button id="btnCreate" style="Z-INDEX: 101; LEFT: 576px; POSITION: absolute; TOP: 48px"
     runat="server" Text="创建HTML文件" OnClick="btnCreate_Click"></asp:Button>
    <asp:TextBox id="txtContent" style="Z-INDEX: 102; LEFT: 208px; POSITION: absolute; TOP: 80px"
     runat="server" TextMode="MultiLine" Height="402px" Width="352px"></asp:TextBox>
    <asp:HyperLink id="hyCreateFile" style="Z-INDEX: 103; LEFT: 584px; POSITION: absolute; TOP: 96px"
     runat="server" Target="_blank">创建的HTML文件</asp:HyperLink>
    <asp:TextBox id="txtTitle" style="Z-INDEX: 104; LEFT: 208px; POSITION: absolute; TOP: 48px" runat="server"
     Width="352px"></asp:TextBox>
    <asp:Label id="Label1" style="Z-INDEX: 105; LEFT: 128px; POSITION: absolute; TOP: 48px" runat="server">页面标题</asp:Label>
    <asp:Label id="Label2" style="Z-INDEX: 106; LEFT: 128px; POSITION: absolute; TOP: 80px" runat="server">页面内容</asp:Label>
   </form>
</body>
</html>

实现代码:default.aspx.cs

using System;
using System.Data;
using System.Configuration;
using System.Collections;//
using System.Web;
using System.Web.Security;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.WebControls.WebParts;
using System.Web.UI.HtmlControls;
using System.Text;//StringBuilder 类命名空间
using System.IO;//读取写入命名空间

public partial class Dhtml : System.Web.UI.Page
{
     protected void Page_Load(object sender, EventArgs e)
     {

     }
     protected void btnCreate_Click(object sender, EventArgs e)
     {
         string[] newContent = new string[5];//定义数组用来保存temphtml.html中的标记数目
         StringBuilder strhtml = new StringBuilder();//实例化一个strhtml
         try
         {
             //创建StreamReader对象 news为TempHtml.html所在的文件夹                           using (StreamReader sr = new StreamReader(Server.MapPath("news") + "//TempHtml.html"))
             {
                 string str;
                 //读取指定的HTML文件模板
                 while ((str = sr.ReadLine()) != null)
                 {
                     strhtml.Append(str);
                 }
                 sr.Close();
             }
         }
         catch (Exception err)
         {
             //异常处理                                                                                                                 Response.Write(err.ToString());
         }
         //为标记数组赋值
         newContent[0] = txtTitle.Text;//标题
         newContent[1] = "BackColor='#cccfff'";//背景色
         newContent[2] = "#ff0000";//字体颜色
         newContent[3] = "100px";//字体大小
         newContent[4] = txtContent.Text;//主要内容

         //根据上面新的内容生成html文件
         try
         {
             //指定要生成的HTML文件
             string fname = Server.MapPath("news") + "//" + DateTime.Now.ToString("yyyymmddhhmmss") + ".html";
             //替换html模版文件里的标记为新的内容
             for (int i = 0; i < 5; i++)
             {
                 strhtml.Replace("$htmlkey[" + i + "]", newContent[i]);
             }
             //创建文件信息对象
             FileInfo finfo = new FileInfo(fname);
             //以打开或者写入的形式创建文件流
             using (FileStream fs = finfo.OpenWrite())
             {
                 //根据上面创建的文件流创建写数据流
                 StreamWriter sw = new StreamWriter(fs, System.Text.Encoding.GetEncoding("GB2312"));
                 //把新的内容写到创建的HTML页面中
                 sw.WriteLine(strhtml);
                 sw.Flush();
                 sw.Close();
             }
             //设置超级链接的属性
             hyCreateFile.Text = DateTime.Now.ToString("yyyymmddhhmmss") + ".html";
             hyCreateFile.NavigateUrl = "news/" + DateTime.Now.ToString("yyyymmddhhmmss") + ".html";
         }
         catch (Exception err)
         {
             Response.Write(err.ToString());
         }
     }
}

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值