MSDN里有描述,VirtualPathProvider只允许在两个地方注册:
1. App_Code目录中任意类的AppInitialize静态方法。
2. Global.asax中的Application_Start方法中。
而我想知道是,有没有什么办法,可以将VirtualPathProvider注册的代码放入外部的dll中,在不需要在App_Code和Global.asax中添加任何代码的情况下,将VirtualPathProvider通过外部dll自动注册。或者,只通过web.config配置也行。
(VirtualPathProvider的作用参考:http://www.cnblogs.com/coderzh/archive/2010/01/26/Sharing-Master-Pages-By-DLL.html )
在App_Code目录里,任意类,实现一个AppInitialize静态方法,原型:
这个方法,将会在Web应用程序初始时自动被调用。因此,考虑在外部dll中定义的AppInitialize方法是否会被执行?
遗憾的是,AppInitialize方法必须在App_Code目录不可。App_Code目录是一个非常特殊的目录,特殊到很多规则你都不知道,ASP.NET对这个目录的文件会做一些特殊的处理。就比如AppInitialize静态方法的执行规则:
1. AppInitialize静态方法必须是在App_Code目录下。
2. AppInitialize静态方法在App_Code目录下不允许被定义两次。
如果AppInitialize在App_Code的两个类中都有定义,比如:
编译时,将会出现编译错误:
AppInitialize方法在编译时就被特殊处理了。推断,AppInitialize方法想在外面的dll中执行几乎是不可能的。
Global.asax继承自HttpApplication,有很多事件(event)可以通过自定义的HttpModule挂上去,比如:AuthenticateRequest,EndRequest。因此,如果HttpApplication有一个类似ApplicationStart的Event,那么我就可以在外部dll中实现一个自定义的HttpModule,然后再Init函数中,将VirtualPathProvider注册的代码挂到ApplicationStart事件中。这样,要做的仅仅是在Web.config中将自定义的HttpModule加进去。可惜,Application_Start并不提供挂载事件。
Application_Start调用的一些细节参考:http://www.dotnet247.com/247reference/msgs/12/62243.aspx
没有任何迹象表明,允许在Web.config中配置VirtualPathProvider的注册。