程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> .NET網頁編程 >> ASP.NET >> 關於ASP.NET >> aspx與ascx,ashx的用法總結

aspx與ascx,ashx的用法總結

編輯:關於ASP.NET

     這篇文章主要是對aspx與ascx,ashx的用法進行了詳細的總結介紹,需要的朋友可以過來參考下,希望對大家有所幫助

    做asp.net開發的對.aspx,.ascx和.ashx都不會陌生。關於它們,網上有很多文章介紹。“紙上得來終覺淺,絕知此事要躬行”,下面自己總結一下做個筆記。   1、.aspx Web窗體設計頁面。Web窗體頁由兩部分組成:視覺元素(html、服務器控件和靜態文本)和該頁的編程邏輯(VS中的設計視圖和代碼視圖可分別看到它們對應得文件)。VS將這兩個組成部分分別存儲在一個單獨的文件中。視覺元素在.aspx 文件中創建。   2、.ascx asp.net的用戶控件,是作為一種封裝了特定功能和行為(這兩者要被用在Web應用程序的各種頁面上)的Web頁面被開發的。一個用戶控件包含了html、代碼和其他Web或者用戶控件的組合,並在Web服務器上以自己的文件格式保存,其擴展名是*.ascx。asp.net裡的缺省配置並不允許Web客戶端通過url來訪問這些文件,但是這個網站的其他頁面可以集成這些文件裡所包含的功能。   3、.ashx  前面兩個都太熟悉了,這個才是要講的重點。   (1)使用舉例 .ashx文件是主要用來寫web handler的。使用.ashx 可以讓你專注於編程而不用管相關的web技術。我們熟知的.aspx是要做html控件樹解析的,.aspx包含的所有html實際上是一個類,所有的html都是類裡面的成員,這個過程在.ashx是不需要的。ashx必須包含IsReusable屬性(這個屬性代表是否可復用,通常為true),而如果要在ashx文件用使用Session必須實現IRequiresSessionState接口. 一個簡單的實現修改登錄用戶密碼的示例:   代碼如下: using System; using System.Collections.Generic; using System.Linq; 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.Web.SessionState;   namespace Test {       public class HandlerTest : IHttpHandler, IRequiresSessionState     {           public void ProcessRequest(HttpContext context)         {             context.Response.ClearContent();             context.Response.ContentType = "text/plain";             context.Response.Cache.SetCacheability(HttpCacheability.NoCache); //無緩存               string action = context.Request.Params["action"]; //外部請求             if (action == "modifyPwd") //用戶改密碼             {                 string oldPwd = context.Request.Params["pwd"];                   //在ashx文件用使用Session必須實現IRequiresSessionState接口                 //Session["LogedUser"]是登錄用戶的會話,用戶名和密碼都是test                 if (oldPwd.ToUpper() != ((context.Session["LogedUser"]) as Customer).Password.ToUpper()) //用戶輸入的舊密碼和當前登錄用戶的不相同                 {                     context.Response.Write("舊密碼輸入錯誤!");                 }                 else                 {                     context.Response.Write("舊密碼輸入正確!");                 }             }                 context.Response.End();         }           public bool IsReusable         {             get             {                 return true;             }         }     } }     客戶端的調用(js和頁面部分):  代碼如下: <%@ Page Language="C#" AutoEventWireup="true" CodeBehind="ASHXTest.aspx.cs" Inherits="ASHXTest" %>   <!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>mytest</title>     <script type="text/javascript">         function $(s) { if (document.getElementById) { return eval('document.getElementById("' + s + '")'); } else { return eval('document.all.' + s); } }           function createXMLHTTP() {             var xmlHttp = false;             var arrSignatures = ["MSXML2.XMLHTTP.5.0", "MSXML2.XMLHTTP.4.0",                          "MSXML2.XMLHTTP.3.0", "MSXML2.XMLHTTP",                          "Microsoft.XMLHTTP"];             for (var i = 0; i < arrSignatures.length; i++) {                 try {                     xmlHttp = new ActiveXObject(arrSignatures[i]);                     return xmlHttp;                 }                 catch (oError) {                     xmlHttp = false; //ignore                 }             }             // throw new Error("MSXML is not installed on your system.");              if (!xmlHttp && typeof XMLHttpRequest != 'undefined') {                 xmlHttp = new XMLHttpRequest();             }             return xmlHttp;         }           var xmlReq = createXMLHTTP();           // 發送ajax處理請求(這裡簡單驗證舊密碼的有效性)         function validateOldPwd(oTxt) {             var url = "/HandlerTest.ashx?action=modifyPwd&pwd=" + escape(oTxt.value); //.ashx文件             xmlReq.open("get", url, true);             xmlReq.setRequestHeader("If-Modified-Since", "0");             xmlReq.onreadystatechange = callBack;             xmlReq.send(url); // 發送文本         }           function callBack() {             if (xmlReq.readyState == 4) {                 if (xmlReq.status == 200) {                     alert(xmlReq.responseText); // 接收文本                 }                 else if (xmlReq.status == 404) {                     alert("Requested URL is not found.");                 } else if (xmlReq.status == 403) {                     alert("Access denied.");                 } else                     alert("status is " + xmlReq.status);             }         }       </script>   </head> <body>     <form id="form1" runat="server">     <div>         <input id="txtOldPwd" type="text" onblur="validateOldPwd(this)" />     </div>     </form> </body> </html>     分析: a、以前我們通常都是通過一個簡單的aspx文件實現的功能,其實通過ashx也可以。 筆者曾經寫過的一篇ajax:數據傳輸方式簡介 ,通過對比,我們發現aspx要將前後台顯示和處理邏輯分開,所以就弄成了兩個文件,其實,在最終編譯的時候,aspx和cs還是會編譯到同一個類中去.這中間就要設計html的一些邏輯處理;而ashx不同,它只是簡單的對web http請求的直接返回你想要返回的結果.比aspx少處理了html的過程(但是ashx也可以處理html的一些邏輯,只是通常都不這麼用)。理論上ashx比aspx要快。   b、還是在相同的舊文裡,我們知道數據傳輸的幾種方式,其實ashx都可以實現(修改ashx文件裡context.Response.ContentType 即可),這裡不再贅述了。   (2)ashx特別適合於生成動態圖片,生成動態文本(純文本,json,xml,javascript等即可)等。    (3).ashx文件有個缺點:它處理控件的回發事件非常麻煩。處理數據的回發,通常都需要一些.aspx頁的功能,只有自己手動處理這些功能(還不如直接建一個aspx文件來處理)。所以,一般使用.ashx輸出一些不需要回發處理的項目即可。    4、總結 aspx-->P(Page) ascx-->C(Control) ashx-->H(HttpHandler)   當浏覽器訪問web服務器,我們最終接收到的還是html文本。浏覽器通過渲染引擎解釋這些標簽,在屏幕上展現出可見的效果。而asp.net不過就是我們應用的一種平台技術來"變相"解釋html的,說白了它就是為了提高生產率,它的技術術語再多,本質上還是html范疇內的東西(如果你不通過那些動態頁面技術完全利用html和浏覽器(當然包括js)技術來實現動態頁面效果,那麼你會發現效果有了代碼量也相當可觀).所以說web開發的底層就是一堆的html標簽,無論是asp.net還是jsp都是對html某種方式的包裝,是html的產物。    
    1. 上一頁:
    2. 下一頁:
    Copyright © 程式師世界 All Rights Reserved