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接口.

一個簡單的實現修改登錄用戶密碼的示例:

aspx,ascx和ashx使用小結 - dingtao-wgs - 程序員驛站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;

????????????}

????????}

????}

}

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

aspx,ascx和ashx使用小結 - dingtao-wgs - 程序員驛站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"?οnblur="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的產物。


轉載于:https://www.cnblogs.com/yefengmeander/archive/2011/11/08/2887989.html

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/247314.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/247314.shtml
英文地址,請注明出處:http://en.pswp.cn/news/247314.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

vue3.x通過ref屬性獲取元素

在vue2.x中&#xff0c;可以通過給元素添加refxxx屬性&#xff0c;然后在代碼中通過this.$refs.xxx獲取到對應的元素 然而在vue3中時沒有$refs這個東西的&#xff0c;因此vue3中通過ref屬性獲取元素就不能按照vue2的方式來獲取vue3需要借助生命周期方法&#xff0c;原因很簡單…

vue3+TypeScript封裝echarts5組件

https://blog.csdn.net/qq_38330707/article/details/111497853 有用mark 等抽時間寫個vueTSecharts5.0的組件文章 寫個大概 帶 resize的 <template><div class"echarts" :id"id"></div> </template><script lang"ts&q…

How to Register COM in VS

在 Visual Studio .Net 部署項目中注冊 COM 模塊的步驟 將 COM 對象添加到 Visual Studio 部署項目。在解決方案資源管理器中&#xff0c;右鍵單擊剛添加的模塊&#xff0c;然后單擊屬性。注意&#xff1a;“屬性”窗口包含一個表&#xff0c;其中有兩列和 x 行&#xff08;行數…

css3 卡片hover3D效果

鼠標hover卡片 向上翻轉&#xff0c;看簡易代碼 <!DOCTYPE html> <html> <head><title>3D Flip Card hover effects</title><style type"text/css">* {margin: 0;padding: 0;font-family: consolas;box-sizing: border-box;}bo…

隨便貼兩個漏洞,如 Apache JServ協議服務

1、Apache JServ協議服務 描述&#xff1a;Apache JServ協議&#xff08;AJP&#xff09;是一種二進制協議&#xff0c;可以將來自Web服務器的入站請求代理到 位于Web服務器后面的應用程序服務器。不建議在互聯網上公開使用AJP服務。 如果AJP配置錯誤&#xff0c;可能會允許攻擊…

vue3學習筆記 Composition API setup

一、Composition API優勢 相對于vue2的option API Vue3的Composition API設計更有優勢 Composition(組合式)Api 功能分組 Composition(組合式)Api 功能導入復用 組合式Api 所解決的問題 (1) 更好的代碼組織結構 (2) 相同的代碼邏輯可以進行復用 home.vue 3種方式遞進升級…

【TCP傳輸數據-鍵盤錄入】

package com.yjf.esupplier.common.test;import java.io.*; import java.net.Socket;/*** author shusheng* description TCP 傳輸數據:鍵盤錄入* Email shushengyiji.com* date 2019/1/15 22:57*/ public class ClientDemo1 {public static void main(String[] args) throws I…

04

1、創建/guanli 目錄&#xff0c;在/guanli下創建zonghe 和 jishu 兩個目錄&#xff08;一條命令&#xff09; [rootlocalhost ~]# mkdir /guanli [rootlocalhost ~]# touch /guanli/zonghe [rootlocalhost ~]# touch /guanli/jishu [rootlocalhost ~]# ls /guanlix 2、添加組帳…

事件冒泡 bubbles cancelBubble stopPropagation() stopImmediatePropagation() 區別

<!DOCTYPE html> <html><head><meta charset"utf-8"><title>事件冒泡</title></head><body><h4>bubbles cancelBubble stopPropagation() stopImmediatePropagation() 區別</h4><input type"te…

vue2.0關于添加屬性后視圖不能更新的問題

屬性賦值和this.$set 和vue.$set方法我不行 可以用 this.$delete來進行刪除后在設置都可以了 轉載于:https://www.cnblogs.com/zhouyideboke/p/11276299.html

vite2.1 最新alias別名設置方式

vite.config.js 別名配置 resolve.alias 類型&#xff1a; Record<string, string> | Array<{ find: string | RegExp, replacement: string }> 將會被傳遞到 rollup/plugin-alias 作為 entries 的選項。也可以是一個對象&#xff0c;或一個 { find, replacement …

Java生鮮電商平臺-商城后臺架構與原型圖實戰

Java生鮮電商平臺-商城后臺架構與原型圖實戰 說明&#xff1a;生鮮電商平臺的運營平臺&#xff0c;其中需要很多的功能進行管理。目前把架構與原型圖實戰分享給大家&#xff0c;希望對大家有用. 儀表盤/首頁&#xff0c;簡單統計&#xff0c;報表頁&#xff0c;運營快捷口。實際…

antdesignvue upload vue3個人筆記待更新

remove點擊移除文件時的回調&#xff0c;返回值為 false 時不移除。支持返回一個 Promise 對象&#xff0c;Promise 對象 resolve(false) 或 reject 時不移除。Function(file): boolean | Promise無 beforeUpload上傳文件之前的鉤子&#xff0c;參數為上傳的文件&#xff0c;若…

logging模塊和包

日志模塊和包 logging logging模塊簡介 logging模塊是記錄我們軟件的各種狀態&#xff0c;還可以記錄各種交易信息 其實每個軟件都是有錯誤日志的,開發人員可以通過錯誤日志中的內容對他的程序進行修改 日志級別 import logginglogging.debug(調試debug) # DEBUG 10…

python軟件開發規范

軟件開發規范 什么是軟件開發規范&#xff1f; 好的設計項目目錄結構&#xff0c;就和編碼風格一樣&#xff0c;是每個程序員都有的風格&#xff0c;但是在流水化標準化作業過程中&#xff0c;個性和風格是 不被鼓勵的。如果你去維護一個非常不好讀的項目&#xff0c;雖然實現邏…

D3Vueecharts個人亂記

利用d3vue開發的一個網絡拓撲圖 https://copyfuture.com/blogs-details/20200710101052238h32wazjmcii49dr 一開始用的是echart畫的。 根據https://gallery.echartsjs.com/editor.html?cxH1Rkt3hkb&#xff0c;成功畫出簡單的節點關系。 如圖&#xff1a; 總結—— 【優…

vue中使用Vue-pdf在線預覽

下載 npm i vue-pdf 引入(在所需要預覽的頁面) <script>import axios from axiosimport pdf from vue-pdfimport CMapReaderFactory from vue-pdf/src/CMapReaderFactory.js // 加載中文的包export default {components: {pdf},data () {return {numPages:&#xff0c;…

oracle 自定義 聚合函數

Oracle自定義聚合函數實現字符串連接的聚合 create or replace type string_sum_obj as object ( --聚合函數的實質就是一個對象 sum_string varchar2(4000), static function ODCIAggregateInitialize(v_self in out string_sum_obj) return number, --對象初始化 member func…

Vue3里的setup中使用vuex

useStore 這里我們可以直接從vuex 4.X中解構出useStore方法&#xff0c;就可以在setup中使用vuex的相關函數 template 使用$store <template><div><h2>{{ $store.state.count }}</h2><button click"increaseCount">點擊</button…

JQ 取CHECKBOX選中項值

備忘錄 $("[namecheckbox]:checked").each(function(){ alert((this).val()); }) ;轉載于:https://www.cnblogs.com/showblog/archive/2010/09/13/1825099.html