|
 |
栏目导栏 |
|
| |
|
|
|
|
 |
资料搜索 |
|
| |
|
|
|
|
 |
热门文章 |
|
| |
|
|
|
|
 |
最新文章 |
|
| |
|
|
|
| |
| |
|
|
|
|
在做项目时,我们一般会将aspx文件和其后台cs文件分开,然后将后台的cs文件编译成dll发布到生产环境中。如果我们的项目规定是每周1发布一次,现在发布后第二天客户在其中某个页面发现一个Bug导致业务无法正常处理,这个时候我们的项目正在添加新的功能,编码还没有完成,不可能为了这一个页面而将这没有完成的整个项目重新发布到生产环境中,这个时候怎么办拉? 9JHLinux联盟 我们知道aspx运行有两种模式,一种是编译运行,一种是解释运行.编译运行就是我们将后台c#代码编译成Dll,在aspx页面运行时调用这个dll来执行.而解释执行就是像是asp一样将后台代码和页面代码放在同一个aspx页面上,由IIS解释c#代码来运行.于是我们想到的解决办法就是专门针对这个页面把其后台CS代码中的bug修正,测试没有问题了,然后将后台cs文件转移到aspx文件中,让将这个新的aspx文件复制到正式环境中,覆盖原来错误的aspx文件。 9JHLinux联盟 将后台的cs代码转移到页面上主要是做如下操作: 9JHLinux联盟 1.去掉aspx头Page部分的CodeFile属性,这个属性指示了页面的后台文件的文件名. 9JHLinux联盟 2.在Page中添加Inherits属性,这个属性的值是页面后台文件的父类,如果页面的父类是System.Web.UI.Page,那么可以不加这个属性. 9JHLinux联盟 3.将后台代码所使用的名字空间添加到aspx的头,使用<%@ Import Namespace="名字空间" %>进行引入. 9JHLinux联盟 4.在aspx页面的最下面添加<script runat="server"></script>,然后将后台代码中类里面的所有变量,属性,方法等等都放在script中. 9JHLinux联盟 通过以上几步我们就可以将后台cs文件转移到aspx页面上,这样让IIS直接解释aspx文件执行,而不是通过调用发布后的dll执行. 9JHLinux联盟 出于平时需要即时修改一个单独页面,所以我写了一个小程序来自动转换后台cs文件到aspx文件中. 9JHLinux联盟 比如一个页面: 9JHLinux联盟 aspx页面 9JHLinux联盟 <%@ Page Language="C#" AutoEventWireup="true" CodeFile="Default.aspx.cs" Inherits="_Default" %> 9JHLinux联盟 9JHLinux联盟 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> 9JHLinux联盟 9JHLinux联盟 <html xmlns="http://www.w3.org/1999/xhtml" > 9JHLinux联盟 <head runat="server"> 9JHLinux联盟 <title>未命名頁面</title> 9JHLinux联盟 </head> 9JHLinux联盟 <body> 9JHLinux联盟 <form id="form1" runat="server"> 9JHLinux联盟 <div> 9JHLinux联盟 9JHLinux联盟 </div> 9JHLinux联盟 </form> 9JHLinux联盟 </body> 9JHLinux联盟 </html> 9JHLinux联盟 对应的后台代码是: 9JHLinux联盟 后台cs代码 9JHLinux联盟 using System; 9JHLinux联盟 using System.Data; 9JHLinux联盟 using System.Configuration; 9JHLinux联盟 using System.Web; 9JHLinux联盟 using System.Web.Security; 9JHLinux联盟 using System.Web.UI; 9JHLinux联盟 using System.Web.UI.WebControls; 9JHLinux联盟 using System.Web.UI.WebControls.WebParts; 9JHLinux联盟 using System.Web.UI.HtmlControls; 9JHLinux联盟 9JHLinux联盟 public partial class _Default : System.Web.UI.Page 9JHLinux联盟 { 9JHLinux联盟 protected void Page_Load(object sender, EventArgs e) 9JHLinux联盟 { 9JHLinux联盟 Response.Write(Hello()); 9JHLinux联盟 } 9JHLinux联盟 private string Hello() 9JHLinux联盟 { 9JHLinux联盟 return "Hello World"; 9JHLinux联盟 } 9JHLinux联盟 } 9JHLinux联盟 我们将这个页面的后台代码写到页面上的代码就是: 9JHLinux联盟 转换后的aspx代码 9JHLinux联盟 <%@ Page Language="C#" AutoEventWireup="true" Inherits="System.Web.UI.Page" %> 9JHLinux联盟 <%@ Import Namespace="System" %> 9JHLinux联盟 <%@ Import Namespace="System.Data" %> 9JHLinux联盟 <%@ Import Namespace="System.Configuration" %> 9JHLinux联盟 <%@ Import Namespace="System.Web" %> 9JHLinux联盟 <%@ Import Namespace="System.Web.Security" %> 9JHLinux联盟 <%@ Import Namespace="System.Web.UI" %> 9JHLinux联盟 <%@ Import Namespace="System.Web.UI.WebControls" %> 9JHLinux联盟 <%@ Import Namespace="System.Web.UI.WebControls.WebParts" %> 9JHLinux联盟 <%@ Import Namespace="System.Web.UI.HtmlControls" %> 9JHLinux联盟 9JHLinux联盟 9JHLinux联盟 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> 9JHLinux联盟 9JHLinux联盟 <html xmlns="http://www.w3.org/1999/xhtml" > 9JHLinux联盟 <head id="Head1" runat="server"> 9JHLinux联盟 <title>未命名頁面</title> 9JHLinux联盟 </head> 9JHLinux联盟 <body> 9JHLinux联盟 <form id="form1" runat="server"> 9JHLinux联盟 <div> 9JHLinux联盟 9JHLinux联盟 </div> 9JHLinux联盟 </form> 9JHLinux联盟 </body> 9JHLinux联盟 </html> 9JHLinux联盟 <script runat="server"> 9JHLinux联盟 protected void Page_Load(object sender, EventArgs e) 9JHLinux联盟 { 9JHLinux联盟 Response.Write(Hello()); 9JHLinux联盟 } 9JHLinux联盟 private string Hello() 9JHLinux联盟 { 9JHLinux联盟 return "Hello World"; 9JHLinux联盟 } 9JHLinux联盟 </script> 9JHLinux联盟 9JHLinux联盟
Linux联盟收集整理 ,转贴请标明原始链接,如有任何疑问欢迎来本站Linux论坛讨论 |
|
|
|
|
|