netinitialize_MVC之前-ASP.NET初始化流程分析1

理论的解说一般都是枯燥的,研究一个代码框架更是如此,似乎除了对大量的源码加以解释之外无话可说,但是这又是不可缺少的,否则应用这样的框架起来总有不放心之感,总有不少的坑要踩。更进一步讲,一个好的框架应该给它的使用者足够的扩展空间(尤其是像MVC这样的基础框架),对框架本身没有很好的把握则对于框架的扩展似乎就只能寻找别人的“成功”经验了,然而生搬硬套从来不是解决问题的好方法,合理运用他人经验与创造性的解决方案都离不开对框架的深入理解,从这方面来说代码分析其实强于抽象的说明,因为代码的逻辑是确定的,代码的语言说服力其实强于书面语言(当然是指编写良好的代码)。当然对于代码之外的讨论也是非常必要甚至更加重要的,比如探讨框架设计的思路和模式,框架应用的相关实践乃至对框架的扩展等等。此一系列文章都是基于Asp.net Mvc框架的源码(包括Asp.net的一部分)对框架的基本设计与实现作出分析,另外参考了自己的一些项目以及当前一些优秀的开源项目(比如orchard)来讨论框架的应用与扩展。

Asp.net Mvc是当前使用比较多的web框架,也是比较先进的框架,目前.net的大部分源码都已经开放,这大大方便了我们对Asp.net Mvc的分析,下面就从Http请求进入Mvc框架处理之前的基本流程说起。

由于各IIS版本和工作模式(经典模式、集成模式)的不同,Http请求进入Asp.net的处理通道并不一样,这里不去细究里面的细节,就从创建应用程序域开始:

AppManagerAppDomainFactory分析

注:AppDomainFactory及AppManagerAppDomainFactory类在System.Web.Hosting中实现

在创建Appdomain时会调用IAppDomainFactory接口,该接口的实现如下:

public sealed classAppDomainFactory : IAppDomainFactory {

privateAppManagerAppDomainFactory _realFactory;

publicAppDomainFactory() {

_realFactory = newAppManagerAppDomainFactory();

}

publicObject Create(String module, String typeName, String appId, String appPath,String strUrlOfAppOrigin, intiZone) {

return_realFactory.Create(appId, appPath);

}

}

该实现会调用AppManagerAppDomainFactory完成实际的创建过程。

public sealed classAppManagerAppDomainFactory : IAppManagerAppDomainFactory {

privateApplicationManager _appManager;

publicAppManagerAppDomainFactory() {

_appManager =ApplicationManager.

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值