asp到asp.net模版转化

来源:互联网 发布:广州42u网络机柜 编辑:程序博客网 时间:2024/05/17 02:36

到一家网站实习,用的asp,我们的任务是改成asp.net的,其中动态管理模版就难住了我,经过努力,参考前辈的asp中的算法,最终解决了

 

 

 

给我提示的asp中实现方法(http://www.cacy.net/Article/ShowArticle.asp?ArticleID=1324)

初学ASP,程序是能勉强写出来了,但若每进行一次网站页面的改版,所有的源程序都将进行一次移植手术。为此所耗费的人力精力不计其数,甚至一不小心得不偿失、前功尽弃。所以,梦想着那么大段的程序代码变成几个简单的字符代替,这样只要设计好页面把该功能插入就OK了。其实这也简单,只需将实现该功能的程序代码做成子程序,然后主页调用就可以了。很多时候,在博客中国,你会选择到很多的模板,甚至有可能自己来设计;或者采用猪飞飞BLOG的各大站长都将其站点改得不近相同……这些,我们都归功于ASP采用模板的功能。那下面偶就借花献佛,将模板拿来分析,以馈各位朋友。

首先,模板需要在线修改,则应采用数据库保存模板代码

所谓的模板,就是设计完工的标准的HTML代码,其中需要由程序实现的功能部分将采用特殊字符串代替。然,这些特殊字符串需要在显示的时候被编译为对应的功能。

2,假设第一模板内容代码

将下列代码拷贝到m_html字段中
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312">
<title>testmb</title>
</head>
<body leftmargin="0" topmargin="0">
<table width="100%" height="100%" border="0" cellpadding="5" cellspacing="2">
  <tr align="right" bgcolor="#CCCCCC">
    <td height="20" colspan="2">$cntoplt;/td>
  </tr>
  <tr valign="top">
    <td width="25%" bgcolor="#e5e5e5">$cnleftlt;/td>
    <td width="74%" bgcolor="#f3f3f3">$cnrightlt;/td>
  </tr>
</table>
</body>
</html>
注意$cntop$、$cnleft$、$cnright$,它们将要实现某些具体的程序功能

3,建立数据库连接文件conn.asp

<%
set conn= Server.CreateObject("ADODB.Connection")
connstr = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source="&Server.MapPath("testmb.mdb")
conn.Open connstr
%>


4,建立特殊字符串转换所需要的库文件lib.asp


 

该文件的主要作用是将实现某些功能的ASP程序做成字程序,以方便调用。


 

<%
dim topcode
sub cntop()
    topcode="现在时间是:"
    topcode=topcode&now()
end sub


 

dim leftcode,i
sub cnleft()
    for i = 1 to 5
    leftcode=leftcode&"<p>cnbruce.com"
    next
end sub


 

dim rightcode
sub cnright()
    for i = 1 to 9
    rightcode=rightcode&"<hr color="&i&i&i&i&i&i&">"
    next
end sub
%>


 


5,最后,调用数据库中的模板代码,将特殊字符串转换。


 

<!--#include file="conn.asp" -->
<!--#include file="lib.asp" -->
<%
sql="select * from moban where m_id=1"
set rs=Server.CreateObject("adodb.recordset")
rs.open sql,conn,1,1
mb_code=rs("m_html")
rs.close
set rs=nothing


 

cntop()
mb_code=replace(mb_code,"$cntop$",topcode)
cnleft()
mb_code=replace(mb_code,"$cnleft$",leftcode)
cnright()
mb_code=replace(mb_code,"$cnright$",rightcode)

response.write mb_code
%> 
该页主要作用是将模板代码进行显示,并将其中的特殊代码转变为相对应子程序功能。 

至此,ASP的模板功能基本完成,剩下的就是:建立具备编辑模板功能的程序页面,将库文件改变为自己所需要程序功能……

 

 

asp.net中实现

1。用户界面

 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.Data.SqlClient;
using System.Text;
namespace localhost.模版后台管理
{
 /// <summary>
 /// UseInterface 的摘要说明。
 /// </summary>
 public class UseInterface : System.Web.UI.Page
 {
  protected string show_string;
  protected StringBuilder show_string2;
  private void Page_Load(object sender, System.EventArgs e)
  {
   // 在此处放置用户代码以初始化页面
   SqlConnection Conn;
   Conn=new SqlConnection("server=localhost;database=Skin;uid=sa;pwd=''");
   Conn.Open();   
   SqlDataAdapter da=new  SqlDataAdapter("select Skin_html from SkinBin where IsDefault=1",Conn);   
   DataSet ds=new DataSet();
   da.Fill(ds,"skin");
//   show_string2.Append(ds.Tables["skin"].Rows[0][0].ToString());
//   show_string2.Replace("$show_blogname$","无影杀手");//替换特殊标记
   show_string=ds.Tables["skin"].Rows[0][0].ToString();
   show_string=show_string.Replace("$show_blogname$","无影杀手");
   Response.Write(show_string);   
  }

  #region Web 窗体设计器生成的代码
  override protected void OnInit(EventArgs e)
  {
   //
   // CODEGEN: 该调用是 ASP.NET Web 窗体设计器所必需的。
   //
   InitializeComponent();
   base.OnInit(e);
  }
  
  /// <summary>
  /// 设计器支持所需的方法 - 不要使用代码编辑器修改
  /// 此方法的内容。
  /// </summary>
  private void InitializeComponent()
  {   
   this.Load += new System.EventHandler(this.Page_Load);
  }
  #endregion
 }
}

2。管理后台

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.Data.SqlClient;
namespace localhost.模版后台管理
{
 /// <summary>
 /// SkinManage 的摘要说明。
 /// </summary>
 public class SkinManage : System.Web.UI.Page
 {
  protected System.Web.UI.WebControls.DataGrid DataGrid2;
 
  private void Page_Load(object sender, System.EventArgs e)
  {
   // 在此处放置用户代码以初始化页面
   // 在此处放置用户代码以初始化页面
   SqlConnection Conn;
   Conn=new SqlConnection("server=localhost;database=Skin;uid=sa;pwd=''");
   Conn.Open();   
   SqlDataAdapter da=new SqlDataAdapter("select Id,Skin_name from SkinBin",Conn);
   DataSet ds=new DataSet();
   da.Fill(ds,"skin");
   da.Fill(ds,"skinall");
//   show_string=ds.Tables["skin"].Rows[0][0].ToString();   
   DataGrid2.DataSource=ds.Tables["skinall"].DefaultView;
   DataGrid2.DataBind();
  }

  #region Web 窗体设计器生成的代码
  override protected void OnInit(EventArgs e)
  {
   //
   // CODEGEN: 该调用是 ASP.NET Web 窗体设计器所必需的。
   //
   InitializeComponent();
   base.OnInit(e);
  }
  
  /// <summary>
  /// 设计器支持所需的方法 - 不要使用代码编辑器修改
  /// 此方法的内容。
  /// </summary>
  private void InitializeComponent()
  {   
   this.DataGrid2.DeleteCommand += new System.Web.UI.WebControls.DataGridCommandEventHandler(this.DataGrid2_DeleteCommand);
   this.Load += new System.EventHandler(this.Page_Load);

  }
  #endregion

  private void DataGrid2_DeleteCommand(object source, System.Web.UI.WebControls.DataGridCommandEventArgs e)
  {
   try
   {
    SqlConnection Conn;
    Conn=new SqlConnection("server=localhost;database=Skin;uid=sa;pwd=''");
    Conn.Open();
    string Id="";
    Id=e.Item.Cells[2].Text;
    SqlCommand Comm=new SqlCommand("update SkinBin set IsDefault=1 where Id="+Id,Conn);
    Comm.ExecuteNonQuery();
   }
   catch
   {

   }
   Response.Write("<script>alert('模版已更改,请查看用户界面');</script>");

  }
 

  
 }
}

3。数据库

if exists (select * from dbo.sysobjects where id = object_id(N'[dbo].[SkinBin]') and OBJECTPROPERTY(id, N'IsUserTable') = 1)
drop table [dbo].[SkinBin]
GO

CREATE TABLE [dbo].[SkinBin] (
 [Id] [int] IDENTITY (1, 1) NOT NULL ,
 [Skin_name] [char] (10) COLLATE Chinese_PRC_CI_AS NULL ,
 [Skin_html] [ntext] COLLATE Chinese_PRC_CI_AS NULL ,
 [IsDefault] [bit] NULL
) ON [PRIMARY] TEXTIMAGE_ON [PRIMARY]
GO