標籤: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的產物。