使用可扩展对象模式扩展HttpApplication

概述

HttpApplication对象对于做ASP.NET开发的朋友,我想没有人不熟悉它。在ASP.NET开发中,经常避免 不了要在HttpApplication中执行一些操作,如使用了ASP.NET MVC框架,就会在Application_Start 事件 中避免不了这样的路由规则配置代码:

protected void Application_Start()
{
   RouteTable.Routes.IgnoreRoute("{resource}.axd/{*pathInfo}");

   RouteTable.Routes.MapRoute(
     "Default",                       // Route name
     "{controller}/{action}/{id}",              // URL with parameters
     new { controller = "Home", action = "Index", id = "" } // Parameter  defaults
   );
}

如果仅仅是这一条,看起来倒不觉的有什么问题,但如果同时在应用程序中使用了工作流,又避免不 了在Application_Start出现启动工作流运行时的代码:

protected void Application_Start()
{
   // 注册路由规则
   RouteTable.Routes.IgnoreRoute("{resource}.axd/{*pathInfo}");
   RouteTable.Routes.MapRoute(
     "Default",                       // Route name
     "{controller}/{action}/{id}",              // URL with parameters
     new { controller = "Home", action = "Index", id = "" } // Parameter  defaults
   );

   // 启动工作流
   WorkflowRuntime workflowRuntime = new WorkflowRuntime ("workflowServicesConfig");
   ExternalDataExchangeService externalDataExchangeService = new  ExternalDataExchangeService();
   workflowRuntime.AddService(externalDataExchangeService);
   workflowRuntime.StartRuntime();
}

试想一下,现在我们仅仅是有了ASP.NET MVC路由规则的配置、WF运行时的启动,如果在应用程序中使 用某种DI框架,如微软的Unity,是不是又避免不了要出现这样的容器初始化代码呢?

protected void Application_Start()
{
   // 注册路由规则
   RouteTable.Routes.IgnoreRoute("{resource}.axd/{*pathInfo}");
   RouteTable.Routes.MapRoute(
     "Default",                       // Route name
     "{controller}/{action}/{id}",              // URL with parameters
     new { controller = "Home", action = "Index", id = "" } // Parameter  defaults
   );

   // 启动工作流
   WorkflowRuntime workflowRuntime = new WorkflowRuntime ("workflowServicesConfig");
   ExternalDataExchangeService externalDataExchangeService = new  ExternalDataExchangeService();
   workflowRuntime.AddService(externalDataExchangeService);
   workflowRuntime.StartRuntime();

   // 初始化DI容器
   IContainerContext repositoryContainer = ContainerManager.GetContainer ("repositoryContainer");
   repositoryContainer.Initialize();
}

再看看Application_Start事件中的代码,有ASP.NET MVC的工作,有WF的工作,也有Unity的工作,不 知道将来还会有什么?这些原本互相之间没有任何联系的代码,现在却同时堆在了一起,当每一部分(或 者说每一个框架)变化的时候,都会涉及到Application_Start中代码的修改,显然违反了OCP原则。那么 有没有一种机制,让这些互不相干的模块之间互相独立,各自发生变化时不影响对HttpApplication?此 时我们就需要对HttpApplication进行扩展,提供一个扩展点,让其他模块的程序附加到HttpApplication 上面。

时间: 2024-09-11 20:38:44

使用可扩展对象模式扩展HttpApplication的相关文章

一起谈.NET技术,技巧:使用可扩展对象模式扩展HttpApplication

概述 HttpApplication对象对于做ASP.NET开发的朋友,我想没有人不熟悉它.在ASP.NET开发中,经常避免不了要在HttpApplication中执行一些操作,如使用了ASP.NET MVC框架,就会在Application_Start 事件中避免不了这样的路由规则配置代码: protected void Application_Start(){RouteTable.Routes.IgnoreRoute("{resource}.axd/{*pathInfo}"); R

技巧:使用可扩展对象模式扩展HttpApplication

概述 HttpApplication对象对于做ASP.NET开发的朋友,我想没有人不熟悉它.在ASP.NET开发中,经常避免不了要在HttpApplication中执行一些操作,如使用了ASP.NET MVC框架,就会在Application_Start 事件中避免不了这样的路由规则配置代码: protected void Application_Start() { RouteTable.Routes.IgnoreRoute("{resource}.axd/{*pathInfo}");

来源于WCF的设计模式:可扩展对象模式[上篇]

我一直很喜欢剖析微软一些产品.框架的底层实现.在我看来,这不但让我们可以更加深入地了解其运作的原理,同时也能提高设计/架构的技能.因为对于这些框架或者产品来说,高质量的设计是它们能够成功的一个最基本的因素.比如说比如ASP.NET,不但能够支持传统的Web Form应用,MVC同样建立在它基础之上.比如说WCF,从其诞生的那一天开始,真个架构体系就从未改变.这些应用在这些产品和框架上的设计其实是最值得我们学习的设计案例.比如说,今天我们介绍的"可扩展对象模式(Extensible Object

来源于WCF的设计模式:可扩展对象模式[下篇]

在<来源于WCF的设计模式:可扩展对象模式>我通过一个简单的例子介绍了基于IExtensibleObject<T>和IExtension<T>这两个接口为核心的"可扩展对象模式".在那篇文章中,我是通过编程的方式来应用扩展到扩展对象的.其实,如何能够通过配置的方式来定义扩展,这个所谓的"可扩展对象模式"将会发挥更大的威力.[源代码从这里下载] 目录: 一.将XxxBuilder定义在配置中 二.ExtensionConfigura

角色对象模式

作者:Dirk Bäumer, Dirk Riehle, Wolf Siberski, and Martina Wulf  原文链接  译者:f0tlo <1357654289@qq.com> 意图 单个对象透过不同的角色对象来满足不同客户的不同需求.每一个角色对象针对不同的客户内容来扮演其角色.对象能够动态的管理其角色集合.角色作为独立的对象是的不同的内容能够简单的被分离开来,系统间的配置也变得容易. 译注:为了行文的流畅性及内容意思的准确性,尽量贴近原文使用英文单词标记特定内容, 如Cus

异构环境中的LDAP模式扩展和迁移

轻量级目录http://www.aliyun.com/zixun/aggregation/34570.html">访问协议 (Lightweight Directory Access Protocol, LDAP) 是一个访问分布式目录服务的 Internet 协议,遵从 X.500 数据和服务模式. LDAP Schema 定义了可在目录中存储的对象类型.Schema 也列出了每个对象类型的属性,以及这些属性是必需的还是可选的. 尽管每个服务器都可定义自己的模式,但是考虑到互操作性,还是

原生js实现复制对象、扩展对象 类似jquery中的extend()方法_javascript技巧

jq的extend()方法能很方便的实现扩展对象方法,语法如下:$.extend(obj1,boj2,obj3); 现在要实现的是:原生js实现复制对象,扩展对象,类似jq中的extend()方法,具体实例如下: 现有3个对象字面量: var o1={hello:1,old:555}, o2 = { abc: 55555555, hello: 2, fun: function() { alert(111); } }, o3={third:9999}; 实现目标: 复制o1对象,把 o2,o3的对

去哪儿下架“双程”门票背后:扩展商业模式引冲突

去哪儿下架"双程"门票背后:扩展商业模式引冲突TechWeb 5月21日报道 文/肖芳近日,在去哪儿上搜索门票时已经不见携程和同程的踪影,取而代之的是驴妈妈以及去哪儿团购的产品.更值得注意的是,对于此次"下架门",去哪儿和携程.同程网的回应却相互矛盾.各执一词.去哪儿称,携程与同程网门票下架原因是未接入SAAS系统,且与其他供应商存在重复的门票资源.对于两家供应商提供的 所谓个别"独家特价资源",去哪儿仍然会进行抓取.但携程和同程网却表示,门票和

JQuery 动态扩展对象之另类视角_jquery

例如:有一个employee对象, 复制代码 代码如下: function employee(){ this.e_id = 0; this.e_name = ""; } 现在需要为它动态的新增"age"属性和"toString()"方法, 复制代码 代码如下: var empObj = new employee(); empObj["age"] = 20; empObj["toString"] = func