现在位置首页 / 项目实战 /正文

aspx,ascx和ashx怎么使用及场景

作者: IT小兵 | 2014年4月13日| 热度:℃ | 评论: |参与:

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.htm = htm&("旧密码输入错误!");  
                }  
                else  
                {  
                    context.htm = htm&("旧密码输入正确!");  
                }  
            }  
  
  
  
  
            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、总结      //重点 有点model view control 的感觉)
aspx-->P(Page)
ascx-->C(Control)
ashx-->H(HttpHandler)



当浏览器访问web服务器,我们最终接收到的还是html文本。浏览器通过渲染引擎解释这些标签,在屏幕上展现出可见的效果。而asp.net不过就是我们应用的一种平台技术来"变相"解释html的,说白了它就是为了提高生产率,它的技术术语再多,本质上还是html范畴内的东西(如果你不通过那些动态页面技术完全利用html和浏览器(当然包括js)技术来实现动态页面效果,那么你会发现效果有了代码量也相当可观).所以说web开发的底层就是一堆的html标签,无论是asp.net还是jsp都是对html某种方式的包装,是html的产物。

点击阅读本文所属分类的更多文章: 项目实战 。和高手一起交流:346717337
友荐云推荐

未注明转发、原文均为本站原创。分享本文请注明 原文链接

给您更多信息和帮助

在这里您可以找到更多:

技术交流群:346717337 Jquery插件交流

投稿:suchso@vip.qq.com

承接:企业网站门户/微网站/微商城/CMS系统/微信公众号运营/业务咨询

抢天猫双11红包
推荐使用阿里云服务器
echarts教程系列
本月最热文章

微信扫一扫,徜徉悠嘻网,您的休闲乐园

微信公众号:快乐每一天

随机文章
标签

技术交流群:346717337

投稿:suchso@vip.qq.com

专业专注:企业网站门户/微网站/微商城/CMS系统/微信公众号运营/付费问题咨询