ASP.NET MVC学前篇之请求流程

本文解析了ASP.NET MVC框架中的请求处理流程,重点讲解了HttpApplication与HttpModule的关系及其实现示例,展示了如何利用事件模型进行自定义操作。

ASP.NET MVC学前篇之请求流程

请求流程描述

对于请求的流程,文章的重点是讲HttpApplication和HttpModule之间的关系,以及一个简单的示例实现。(HttpModule又是MVC框架的入口点)

 图1

在请求到达Web服务器过后进入ASP.NET的时候是通过ASP.NET来构造出一个HttpWorkerRequest对象,HttpWorkerRequest是抽象类类型,表示着一些请求处理的信息,然后由ASP.NET中的HttpRuntime类型来调用静态函数ProcessRequest(),参数类型为HttpWorkerRequest,因为HttpWorkerRequest是抽象的,在使用的时候应该是系统内部会有个实现类。 在ProcessRequest()方法的内部产生HttpApplication对象,这之间的过程,已经把HttpWorkerPequest对象处理后转变到HttpRequest对象,HttpRequest对象是公开的可代码访问的(图中没有表示出来)。 这个时候还没有执行HttpHandler程序,而是先执行HttpModule中的内容,它们订阅了HttpApplication中的事件用于在请求的各种状态之间做一下自定义的修改(这些在下面的示例中会说到。 然后执行HttpHandler,在处理程序执行完毕后,不是到HttpResponse,而是又到了HttpModule中执行请求完成后的一些自定义操作,这是在HttpApplication中约定好的,在这些都完成的情况下才会做Response操作。

我们将在下面的示例中模拟的演示一下在HttpApplication类型中的事件使用模型。

示例部分

代码1-1

 

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
public  delegate  void  PassNotice(NoticeContext noticeContext);
     public  class  Order
     {
         private  NoticeContext _noticeContext;
         public  NoticeContext NoticeContext
         {
             get  return  _noticeContext; }
             set  { _noticeContext = value; }
         }
         private  PassNotice _befPassNotice;
         public  event  PassNotice BefPassNotice
         {
             add
             {
                 _befPassNotice += value;
             }
             remove
             {
                 _befPassNotice -= value;
             }
         }
         private  PassNotice _latPassNotice;
         public  event  PassNotice LatPassNotice
         {
             add
             {
                 _latPassNotice += value;
             }
             remove
             {
                 _latPassNotice -= value;
             }
         }
         private  void  SendGoods()
         {
             Console.WriteLine( "发货…… 请等待接收" );
         }
         public  void  Start()
         {
             if  (_befPassNotice !=  null )
             {
                 _befPassNotice(NoticeContext);
             }
             if  (NoticeContext.IsSend)
             {
                 Console.WriteLine( "服务端:客户端已确认可以发货" );
                 SendGoods();
                 if  (_latPassNotice !=  null )
                 {
                     _latPassNotice(NoticeContext);
                 }
                 if  (NoticeContext.IsAccept)
                 {
                     Console.WriteLine( "服务端:客户端已收货" );
                 }
             }
             else
             {
                 Console.WriteLine( "服务端:等待客户端确认" );
             }
         }
     }

 

Order类代表着订单(这里这个比喻有点不恰当),里面有着两个PassNotice委托类型的事件BefPassNotice、LatPassNotice,分别表示订单发货前的验证和发货后的客户可针对的操作(对应着HttpApplication中的各种事件),再看一下客户类

 代码1-2

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
public  class  NoticeContext
     {
         public  bool  IsSend {  get set ; }
         public  bool  IsAccept {  get set ; }
     }
     public  class  Customer
     {
         private  Order _Order;
         public  Customer(Order order)
         {
             _Order = order;
             _Order.BefPassNotice +=  new  PassNotice(_Order_BefPassNotice);
             _Order.LatPassNotice +=  new  PassNotice(_Order_LatPassNotice);
         }
         void  _Order_LatPassNotice(NoticeContext noticeContext)
         {
             noticeContext.IsAccept =  true ;
             Console.WriteLine( "客户端:接收货物" );
         }
         void  _Order_BefPassNotice(NoticeContext noticeContext)
         {
             noticeContext.IsSend =  true ;
             Console.WriteLine( "客户端:可以发货" );
         }
     }

View Code

这里Customer类有着对Order类的引用,并且订阅Order类的事件,从而可以处理到Order类中的NoticeContex类型值(类似于HttpModule)。

调用
代码1-3

1
2
3
4
             Order order =  new  Order();
             Customer customer =  new  Customer(order);
             order.NoticeContext =  new  NoticeContext() { IsAccept =  false , IsSend =  false  };
             order.Start();

结果如图2所示
图2


示例中还有很多地方没有说明白,只演示了一个大概的模型,还有要说的就是Order类型对应着的处理是单一的(示例中欠妥),就好比HttpApplication只能对应着一个请求一样,当前的上下文信息中也只是存放着当前请求的信息。
在代码1-3中对Customer是直接的调用的,而在ASP.NET中不是这样的。

下一篇将会讲到MVC中的路由部分,对于这个学前篇系列慢慢来完善吧。

 





     本文转自jinyuan0829 51CTO博客,原文链接:http://blog.51cto.com/jinyuan/1423990,如需转载请自行联系原作者





评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值