aspx,ascx和ashx使用小結

作asp.net開發的對.aspx,.ascx和.ashx都不會陌生。關於它們,網上有不少文章介紹。「紙上得來終覺淺,絕知此事要躬行」,下面本身總結一下作個筆記。
一、.aspx
Web窗體設計頁面。Web窗體頁由兩部分組成:視覺元素(html、服務器控件和靜態文本)和該頁的編程邏輯(VS中的設計視圖和代碼視圖可分別看到它們對應得文件)。VS將這兩個組成部分分別存儲在一個單獨的文件中。視覺元素在.aspx 文件中建立。
二、.ascx
asp.net的用戶控件,是做爲一種封裝了特定功能和行爲(這二者要被用在Web應用程序的各類頁面上)的Web頁面被開發的。一個用戶控件包含了html、代碼和其餘Web或者用戶控件的組合,並在Web服務器上以本身的文件格式保存,其擴展名是*.ascx。asp.net裏的缺省配置並不容許Web客戶端經過url來訪問這些文件,可是這個網站的其餘頁面能夠集成這些文件裏所包含的功能。
三、.ashx
前面兩個都太熟悉了,這個纔是要講的重點。
(1)、使用舉例
.ashx文件是主要用來寫web handler的。使用.ashx 可讓你專一於編程而不用管相關的web技術。咱們熟知的.aspx是要作html控件樹解析的,.aspx包含的全部html其實是一個類,全部的html都是類裏面的成員,這個過程在.ashx是不須要的。ashx必須包含IsReusable屬性(這個屬性表明是否可複用,一般爲true),而若是要在ashx文件用使用Session必須實現IRequiresSessionState接口.
一個簡單的實現修改登陸用戶密碼的示例:javascript

Code
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;
            }
        }
    }
}

html

客戶端的調用(js和頁面部分):java

Code
<%@ 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>

web

分析:
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輸出一些不須要回發處理的項目便可。
四、總結
aspx-->P(Page)
ascx-->C(Control)
ashx-->H(HttpHandler)ajax

當瀏覽器訪問web服務器,咱們最終接收到的仍是html文本。瀏覽器經過渲染引擎解釋這些標籤,在屏幕上展示出可見的效果。而asp.net不過就是咱們應用的一種平臺技術來"變相"解釋html的,說白了它就是爲了提升生產率,它的技術術語再多,本質上仍是html範疇內的東西(若是你不經過那些動態頁面技術徹底利用html和瀏覽器(固然包括js)技術來實現動態頁面效果,那麼你會發現效果有了代碼量也至關可觀).因此說web開發的底層就是一堆的html標籤,不管是asp.net仍是jsp都是對html某種方式的包裝,是html的產物。編程

相關文章
相關標籤/搜索