2011-06-26 12 views
10

Próbuję dostać mój wildcard http handler to handle *.cshtml pages ale wniosek nie sięga mój obsługi jak to wygląda jakby przed przechwyceniem przez WebPageHttpModule że odkryłem istnieje pośrednictwem tej StackTrace:Jak mogę wyłączyć/usunąć WebPageHttpModule z aplikacji internetowych ASP.NET 4.0?

[HttpException (0x80004005): Exception of type 'System.Web.HttpException' was thrown.] 
    System.Web.WebPages.ApplicationStartPage.ExecuteStartPage(HttpApplication application, Action`1 monitorFile, Func`2 fileExists, Func`2 createInstance, IEnumerable`1 supportedExtensions) +88 
    System.Web.WebPages.ApplicationStartPage.ExecuteStartPage(HttpApplication application) +287 
    System.Web.WebPages.WebPageHttpModule.StartApplication(HttpApplication application, Action`1 executeStartPage, EventHandler applicationStart) +113 
    System.Web.WebPages.WebPageHttpModule.StartApplication(HttpApplication application) +71 
    System.Web.WebPages.WebPageHttpModule.Init(HttpApplication application) +156 
    System.Web.HttpApplication.RegisterEventSubscriptionsWithIIS(IntPtr appContext, HttpContext context, MethodInfo[] handlers) +431 
    System.Web.HttpApplication.InitSpecial(HttpApplicationState state, MethodInfo[] handlers, IntPtr appContext, HttpContext context) +194 
    System.Web.HttpApplicationFactory.GetSpecialApplicationInstance(IntPtr appContext, HttpContext context) +339 
    System.Web.Hosting.PipelineRuntime.InitializeApplication(IntPtr appContext) +253 

[HttpException (0x80004005): Exception of type 'System.Web.HttpException' was thrown.] 
    System.Web.HttpRuntime.FirstRequestInit(HttpContext context) +8972180 
    System.Web.HttpRuntime.EnsureFirstRequestInit(HttpContext context) +97 
    System.Web.HttpRuntime.ProcessRequestNotificationPrivate(IIS7WorkerRequest wr, HttpContext context) +256 

Próbowałem wyłączyć wszystkie HttpModules korzystania web.config, ale to nie ma żadnego wpływu, (to też nie pojawiają się w sekcji IIS httpModules):

<system.web> 
    <httpModules> 
     <clear/> 
    </httpModules> 
</system.web> 
    .... 
<system.webServer> 
    <modules runAllManagedModulesForAllRequests="true"> 
     <clear/> 
    </modules> 
</system.webServer> 

Polowanie wokół z ILSpy ujawnia następujący kod w System.Web.WebPages.dll jest co rejestracji WebPageHttpModule:

namespace System.Web.WebPages 
{ 
    [EditorBrowsable(EditorBrowsableState.Never)] 
    public static class PreApplicationStartCode 
    { 
     private static bool _startWasCalled; 
     public static void Start() 
     { 
      if (PreApplicationStartCode._startWasCalled) 
      { 
       return; 
      } 
      PreApplicationStartCode._startWasCalled = true; 
      WebPageHttpHandler.RegisterExtension("cshtml"); 
      WebPageHttpHandler.RegisterExtension("vbhtml"); 
      PageParser.EnableLongStringsAsResources = false; 
      DynamicModuleUtility.RegisterModule(typeof(WebPageHttpModule)); 
      ScopeStorage.CurrentProvider = new AspNetRequestScopeStorageProvider(); 
     } 
    } 
} 

Ale to wanilia .NET 4.0 wniosku i nie mają odniesienia do jakichkolwiek System.Web.WebPages, MVC lub bibliotek DLL Razor Jestem tylko przedstawieniu System.Web.

Jak są ładowane te zespoły, dlaczego rejestrowany jest WebPageHttpModule i jak mogę go usunąć/wyłączyć?

Odpowiedz

8

Jeśli próbujesz wyłączyć stron internetowych ASP.NET, można ustawić tę flagę w ustawieniach aplikacji:

<add key="webpages:Enabled" value="false" /> 
+0

ta nie działa dla mnie. Wciąż kończę z 404 dla wszystkich adresów URL kończących się na '.cshtml' Próbuję napisać przeglądarkę kodu źródłowego, i nie mogę mieć jej na * żadnym * rozszerzeniu adresu URL. Jakieś sugestie? –

+0

Och, zapomniałem wspomnieć, że mam osobne pytanie na ten temat: http://stackoverflow.com/questions/7210515/routing-requests-that-end-in-cshtml-to-a-lontroller –

2

Po prostu kopałem, a część kodu jest ... szorstka, delikatnie mówiąc.

Oto wycinek kodu z WebPageHttpHandler:

namespace System.Web.WebPages 
{ 
    public class WebPageHttpHandler : IHttpHandler, IRequiresSessionState 
    { 
    private static List<string> _supportedExtensions = new List<string>(); 

    public static void RegisterExtension(string extension) 
    { 
     WebPageHttpHandler._supportedExtensions.Add(extension); 
    } 

    // [snip] 
} 

Jeśli jesteś gotów użyć refleksji i używasz w pełne zaufanie, można uzyskać dostęp do statycznego pola prywatną _supportedExtensions z WebPageHttpHandler poprzez odbicie i usuń elementy cshtml i vbhtml z listy we własnej procedurze obsługi PreApplicationInit. Z tego co widziałem w DynamicModuleUtility, usunięcie rejestracji WebPageHttpHandler byłoby bardziej zaangażowane.

Powiązane problemy