ASP.NET運行機制之一般處理常式(ashx)

來源:互聯網
上載者:User

標籤:des   style   blog   http   java   使用   

一. 概述 

   建立一個ashx檔案  代碼如下

<%@ WebHandler Language="C#" Class="TestHandler" %>using System;using System.Web;public class TestHandler : IHttpHandler {    //dd    public void ProcessRequest (HttpContext context) {        context.Response.ContentType = "text/plain";        context.Response.Write("Hello World");    }    //dd    public bool IsReusable {        get {            return false;        }    }} 

二. 解析 

   1).

<%@ WebHandler Language="C#" Class="TestHandler" %> 

     @WebHandler為ASP.NET頁面的一個指令 指定為Http handler檔案(.ashx)定義屬性(Attribute)和編譯選項

       屬性 
            Class 指定一個繼承自IHttpHandler的類,當handler被請求時將被執行個體化用來響應請求。這個屬性是必須的 
            CodeBehind 指定Class對應的檔案,基本上沒用,主要是用來支援VS顯示的,可以去掉。 
  
      編譯選項 
           Debug 預設是false,所以非調試就不用開啟,影響效能,可以省略 
           Description 關於當前handler的描述,ASP.NET解析時忽略,可能調試時能提供輔助資訊,可以省略 
           Language 預設C# ,可以省略 
           WarningLevel 0-4 有預設值,可以省略。

   2).

 

        接下來是底下建立的類

                    實現了一個關鍵的介面:System.Web.IHttpHandler。實現它表明將以何種方式來處理來自外部的請求。

                             參數context是System.Web.HttpContext類型

                             context對象提供對用於為 HTTP 要求提供服務的內部伺服器對象(如 Request、Response、

                                         Session 和 Server)的引用,也即可以訪問我們的幾大伺服器對象。

                              可以在ProcessRequest方法中編寫如何處理請求的細節

<%@ WebHandler Language="C#" Class="ImageHandler" %>using System;using System.Web;/// <summary>/// 這就一個沒有任何實現的一般處理常式。/// </summary>public class ImageHandler : IHttpHandler {        public void ProcessRequest (HttpContext context)    {        //擷取虛擬目錄的實體路徑。         string path = context.Server.MapPath("");        //擷取圖片檔案的位元據。        byte[] datas = System.IO.File.ReadAllBytes(path +     http://www.cnblogs.com/dongpo888/admin/file:////123.jpg);       //將位元據寫入到輸出資料流中。        context.Response.OutputStream.Write(datas, 0, datas.Length);    }     public bool IsReusable     {        get {            return false;             }    }}

 

而IsReusable表明其它的請求是否可以使用這個類的一個執行個體。

 

使用ashx的好處就是不需要在Web.Config中配置,就可以直接用IHttpHandler衍生類別來處理請求。

常見的應用情境:動態產生圖片(比如驗證碼),響應Ajax請求等。

 

三. aspx、ascx和ashx

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介面.
一個簡單的實現修改登入使用者密碼的樣本:


<!--<br /><br />Code highlighting produced by Actipro CodeHighlighter (freeware)<br />http://www.CodeHighlighter.com/<br /><br />-->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和頁面部分):


<!--<br /><br />Code highlighting produced by Actipro CodeHighlighter (freeware)<br />http://www.CodeHighlighter.com/<br /><br />--><%@ 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的產物。

相關關鍵詞:
相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.