Asp.net生成静态页面最简单方法(源码)

简介:

public string IssuanceHTML(string NC_Id_S)

{

string returnValue = "";

string htmlfilename=DateTime.Now.ToString("yyyyMMddHHmmss")+".html";

        SqlConnection conn = null;

        SqlDataReader sdr = null;

        try

        {

            string[] NC_Id_SS = NC_Id_S.Split(','); //批量操作时 Split分离数据

            for (int i = 0; i < NC_Id_SS.Length; i++)  //循环生成

            {conn = Connection.CreateDbConn();

             conn.Open();

             SqlCommand cmd = new SqlCommand();

cmd.Connection = conn;

    cmd.CommandText = "SELECT NC_Name_S, NC_Content_S FROM NewsContent WHERE NC_Id_S = '" + NC_Id_S + "'";

    sdr = cmd.ExecuteReader();

sdr.Read();

string path = HttpContext.Current.Server.MapPath("/HTML/"); //生成文件路径

    Encoding code = Encoding.GetEncoding("gb2312"); //编码规则

    string temp = HttpContext.Current.Server.MapPath("/Templet/C8Article.html"); 模版文件

    StreamReader sr = null;

    StreamWriter sw = null;

    string str = "";

    sr = new StreamReader(temp, code);

    str = sr.ReadToEnd();

    sr.Close();

    str = str.Replace("spagetitle", sdr.GetString(0).ToString());//spagetitle为模版文件中内容

    str = str.Replace("scontent", sdr.GetString(1).ToString());

    sw = new StreamWriter(path + htmlfilename, false, code);

    sw.Write(str);

    sw.Flush();

    sw.Close();

    returnValue = "yes";

     }

        catch(Exception e)

        {  returnValue = e.Message.ToString();

        }

        finally

        {   sdr.Close();

            conn.Close();

        }

        return returnValue;

}

--------------------------------------------------------------------------------------------
另外一个代码
--------------------------------------------------------------------------------------------
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   Mysqlserver; 
using   System.IO; 
using   System.Text; 
namespace   NewsAdd 

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

                } 
                protected   void   Button1_Click(object   sender,   EventArgs   e) 
                { 
                        string   strDate   =   DateTime.Now.ToString( "yyMMdd ")   +   "\ "   +   DateTime.Now.ToString( "yyyymmddhhmmss "); 
                        string   strFileName   =   strDate   +   ".shtml "; 
                        string   strTitle=Request.Form[ "Title "].ToString().Trim(); 
                        string   strContent=Request.Form[ "Content "].ToString().Trim(); 
                        string[]   content   =   strContent.Split(new   Char[]   ...{ ' ¦ '}); 
                        int   upbound   =   content.Length; 
                        SqlServerDataBase   db   =   new   SqlServerDataBase(); 
                        bool   success   =   db.Insert( "insert   into   inNews(Title,Content,FilePath)values( ' "   +   strTitle   +   " ', ' "   +   strContent   +   " ', ' "   +   strFileName   +   " ') ",   null); 

                        string   dir   =   Server.MapPath( "http://www.cnblogs.com/ "+ "NewsFiles/ "+DateTime.Now.ToString( "yyMMdd ")); 
                        if   (!Directory.Exists(dir)) 
                        { 
                                Directory.CreateDirectory(dir); 
                        } 

                        try 
                        { 
                        for   (int   i   =   0;   i   <   content.Length;   i++) 
                        { 
                        //string[]   newContent   =   new   string[4]; 
                        StringBuilder   strhtml   =   new   StringBuilder(); 
                                using   (StreamReader   sr   =   new   StreamReader(Server.MapPath( "http://www.cnblogs.com/ "   +   "NewsFiles/ ")   +   "\template.html ",Encoding.GetEncoding( "gb2312 "))) 
                                { 
                                        String   oneline; 
                                        while   ((oneline   =   sr.ReadLine())   !=   null) 
                                        { 
                                                strhtml.Append(oneline); 
                                        } 
                                        sr.Close(); 
                                } 
                        DataSet   ds   =   db.Select( "select   top   1   NewsId   from   inNews   order   by   NewsId   desc ",   null); 
                        string   strTable   =   " <table> <tr> <td> $upUrl </td> <td> $Number </td> <td> $downUrl </td> </tr> </table> "; 
                                string   FilePath= " "; 
                                strhtml   =   strhtml.Replace( "$Title ",   strTitle); 
                                strhtml   =   strhtml.Replace( "$NewsId ",   ds.Tables[0].Rows[0][ "NewsId "].ToString()); 
                                strhtml   =   strhtml.Replace( "$Time ",   DateTime.Now.ToString( "yyyy/MM/dd ")); 
                                strhtml   =   strhtml.Replace( "$Content ",   content[i]); 
                                string   strNumber   =   " "; 
                                for   (int   m   =   1;   m   <=upbound;   m++) 
                                { 
                                        if   (m   ==   1) 
                                                strNumber   =   strNumber   +   "   [ "+ " <a   href= "   +   "../ "   +   strDate   +   ".shtml "   +   "> "   +   m   +   " </a> "+ "]   "; 
                                        else 
                                        { 
                                                int   n   =   m   -   1; 
                                                strNumber   =   strNumber   +   "   [ "   + " <a   href= "   +   "../ "   +   strDate   +   "_ "   +   n   +   ".shtml "   +   "> "   +     m   +   " </a> "+ "]   "; 
                                        } 
                                } 
                                        if   (upbound   ==   0) 
                                        { 
                                                FilePath   =   Server.MapPath( "http://www.cnblogs.com/ ")   +   "NewsFiles "   +   "// "   +   strDate   +   ".shtml "; 
                                                strhtml   =   strhtml.Replace( "$Pager ",   " "); 
                                        } 
                                        else 
                                        { 
                                                if   (i   ==   0) 
                                                        FilePath   =   Server.MapPath( "http://www.cnblogs.com/ ")   +   "NewsFiles "   +   "// "   +   strDate   +   ".shtml "; 
                                                else 
                                                        FilePath   =   Server.MapPath( "http://www.cnblogs.com/ ")   +   "NewsFiles "   +   "// "   +   strDate   +   "_ "   +   i   +   ".shtml "; 
                                                
                                                if   (i   ==   0) 
                                                        strTable   =   strTable.Replace( "$upUrl ",   " ");   

                                                if   (i   <=   1)//上一页分页 
                                                        strTable   =   strTable.Replace( "$upUrl ",   " <a   href= "   +   "../ "   +   strDate   +   ".shtml "   +   "> 上一页 </a> "); 
                                                else 
                                                { 
                                                        int   p   =   i   -   1; 
                                                        strTable   =   strTable.Replace( "$upUrl ",   " <a   href= "   +   "../ "   +   strDate   +   "_ "   +   p   +   ".shtml "   +   "> 上一页 </a> "); 
                                                } 
                                                
                                                if(upbound==1) 
                                                strTable   =   strTable.Replace( "$Number ",   " "); 
                                                else 
                                                strTable   =   strTable.Replace( "$Number ",   strNumber); 
                                                if(i==upbound-1) 
                                                        strTable   =   strTable.Replace( "$downUrl ",   " "); 

                                                if   (i   !=   upbound   -   1) 
                                                { 
                                                        int   q   =   i   +   1; 
                                                        strTable   =   strTable.Replace( "$downUrl ",   " <a   href= "   +   "../ "   +   strDate   +   "_ "   +   q   +   ".shtml "   +   "> 下一页 </a> "); 
                                                } 
                                                else 
                                                { 
                                                        int   j   =   upbound   -   1; 
                                                        strTable   =   strTable.Replace( "$downUrl ",   " <a   href= "   +   "../ "   +   strDate   +   "_ "   +   j   +   ".shtml "   +   "> 下一页 </a> "); 
                                                } 

                                                strhtml   =   strhtml.Replace( "$Pager ",   strTable); 
                                        } 
                                FileInfo   finfo   =   new   FileInfo(FilePath); 
                                using   (FileStream   fs   =   finfo.OpenWrite()) 
                                { 
                                        StreamWriter   sw   =   new   StreamWriter(fs,   System.Text.Encoding.Default); 
                                        sw.WriteLine(strhtml); 
                                        sw.Flush(); 
                                        sw.Close(); 
                                } 
                        } 
                } 
                catch   (Exception   err) 
                { 
                        Response.Write(err.ToString()); 
                } 
                } 


 



本文转自灵动生活博客园博客,原文链接:http://www.cnblogs.com/ywqu/archive/2008/01/05/1027399.html,如需转载请自行联系原作者

相关文章
|
5月前
|
SQL 缓存 开发框架
分享一个 .NET EF6 应用二级缓存提高性能的方法
分享一个 .NET EF6 应用二级缓存提高性能的方法
|
5月前
|
程序员 数据库
分享 2 个 .NET EF 6 只更新某些字段的方法
分享 2 个 .NET EF 6 只更新某些字段的方法
124 0
|
5月前
|
数据库
分享一个 .NET EF 6 扩展 Where 的方法
分享一个 .NET EF 6 扩展 Where 的方法
|
5月前
|
开发框架 前端开发 算法
分享 .NET EF6 查询并返回树形结构数据的 2 个思路和具体实现方法
分享 .NET EF6 查询并返回树形结构数据的 2 个思路和具体实现方法
|
5月前
|
开发框架 中间件 .NET
分享 ASP.NET Core Web Api 中间件获取 Request Body 两个方法
分享 ASP.NET Core Web Api 中间件获取 Request Body 两个方法
212 0
|
5月前
|
开发框架 .NET API
如何在 ASP.NET Core Web API 方法执行前后 “偷偷“ 作一些 “坏“ 事?初识 ActionFilterAttribute
如何在 ASP.NET Core Web API 方法执行前后 “偷偷“ 作一些 “坏“ 事?初识 ActionFilterAttribute
|
5月前
|
开发框架 前端开发 .NET
Asp.net Webapi 的 Post 方法不能把参数加到 URL 中?试试这样写
Asp.net Webapi 的 Post 方法不能把参数加到 URL 中?试试这样写
|
4月前
|
开发框架 前端开发 JavaScript
ASP.NET MVC 教程
ASP.NET 是一个使用 HTML、CSS、JavaScript 和服务器脚本创建网页和网站的开发框架。
51 7
|
4月前
|
存储 开发框架 前端开发
ASP.NET MVC 迅速集成 SignalR
ASP.NET MVC 迅速集成 SignalR
87 0
|
5月前
|
开发框架 前端开发 .NET
ASP.NET MVC WebApi 接口返回 JOSN 日期格式化 date format
ASP.NET MVC WebApi 接口返回 JOSN 日期格式化 date format
69 0

相关实验场景

更多