ASP.NET生成静态网页的方法

 
ASP.NET生成静态网页的方法
 
作者:未知 文章来源:管理员世界论坛 点击数:165 更新时间:2006-8-25           ★★★
 
环境: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.WriteFilethis.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>   
 
 
using System;
using System.Collections;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Web;
using System.Web.SessionState;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.HtmlControls;
using System.IO;
using System.Text;
namespace jindutiao
{
 /// <summary>
 /// WebForm1 的摘要说明。
 /// </summary>
 public class WebForm1 : System.Web.UI.Page
 {
 protected System.Web.UI.WebControls.TextBox title;
 protected System.Web.UI.WebControls.TextBox content;
 protected System.Web.UI.WebControls.TextBox author;
 protected System.Web.UI.WebControls.Button Button1;
 
 private void Page_Load(object sender, System.EventArgs e)
 {
   // 在此处放置用户代码以初始化页面
 
 }
 #region Web 窗体设计器生成的代码
 override protected void OnInit(EventArgs e)
 {
   //
   // CODEGEN: 该调用是 ASP.NET Web 窗体设计器所必需的。
   //
   InitializeComponent();
   base.OnInit(e);
 }
 
 /// <summary>
 /// 设计器支持所需的方法 - 不要使用代码编辑器修改
 /// 此方法的内容。
 /// </summary>
 private void InitializeComponent()
 {    
   this.Button1.Click += new System.EventHandler(this.Button1_Click);
   this.Load += new System.EventHandler(this.Page_Load);
 }
 #endregion
 private void Button1_Click(object sender, System.EventArgs e)
 {//写入文件
   writefile(this.title.Text.ToString(),this.content.Text.ToString(),this.author.Text.ToString());
 }
 public void writefile(string strtext,string strcontent,string strauthor)
 {
   string Path =Server.MapPath("news/");  
   Encoding code = Encoding.GetEncoding("gb2312");
   // 读取模板文件
   string temp = 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)
   {
    Response.Write(exp.Message);
    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();
    Response.Write("文件写入成功!");
   }
  catch(Exception ex)
   {
    Response.Write(ex.Message);
    Response.End();
   }
   finally
   {
    sw.Close();
   }
 }
 }
}
 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值