IIS 7 falha ao servir páginas .aspx mas funciona com arquivos padrão

3

Eu implantei um site da Web ASP.NET 4 no IIS 7 no Windows Server 2008. Quando navego até a pasta raiz ou qualquer outra pasta no site, o servidor responde entregando a página padrão Default.aspx à medida que você esperaria. No entanto, quando eu solicito uma página específica com uma extensão .aspx , recebo um erro 404.

Por exemplo, quando eu solicito:

http://localhost/MyWeb/

o servidor entrega com sucesso http://localhost/MyWeb/Default.aspx . No entanto, se eu solicitar explicitamente:

http://localhost/MyWeb/Default.aspx

o IIS responde com um erro 404.

Os detalhes do erro são os seguintes:

Module: IIS Web Core
Notification: MapRequestHandler
Handler: StaticFile
Error code: 0x80070002

O .NET framework está obviamente instalado e funcionando, já que posso acessar as páginas padrão. A propósito, observei que, quando o servidor falha e mostra uma página de erro 404, a URL que eu inseri (como http://localhost/MyWeb/Default.aspx ) descarta a extensão (e lê http://localhost/MyWeb/Default ).

Eu tentei executar aspnet_iisreg -i e reiniciar o servidor, mas as coisas não mudaram.

O que estou perdendo? Obrigado.

UPDATE. Estou postando aqui o web.config do meu site. Não há outros arquivos de configuração que se apliquem a ele.

<?xml version="1.0" encoding="utf-8"?>
<!--
  For more information on how to configure your ASP.NET application, please visit
  http://go.microsoft.com/fwlink/?LinkId=169433
  -->
<configuration>

  <appSettings>
    <add key="DatabaseServer" value="CONWAY\SQLEXPRESS"/>
    <add key="DatabaseName" value="KaleidoScape"/>
    <add key="User" value="KaleidoScapeUser"/>
    <add key="Password" value="Scape1!"/>
  </appSettings>

  <system.web>

    <compilation debug="true" targetFramework="4.6.1" />
    <httpRuntime targetFramework="4.6.1" />

    <pages>
      <namespaces>
        <add namespace="System.Web.Optimization" />
      </namespaces>
      <controls>
        <add assembly="Microsoft.AspNet.Web.Optimization.WebForms" namespace="Microsoft.AspNet.Web.Optimization.WebForms" tagPrefix="webopt" />
        <add tagPrefix="uc" tagName="FileGallery" src="~/Controls/FileGallery/FileGallery.ascx" />
      </controls>
    </pages>

    <authentication mode="Forms">
      <forms defaultUrl="~/App" loginUrl="~/Default.aspx" slidingExpiration="true" timeout="120" name="Incipit.KaleidoScape" />
    </authentication>

    <authorization>
      <allow users="*" />
    </authorization>

  </system.web>

  <location path="App">
    <system.web>
      <authorization>
        <deny users="?" />
      </authorization>
    </system.web>
  </location>

  <runtime>
    <assemblyBinding xmlns="urn:schemas-microsoft-com:asm.v1">
      <dependentAssembly>
        <assemblyIdentity name="Newtonsoft.Json" culture="neutral" publicKeyToken="30ad4fe6b2a6aeed" />
        <bindingRedirect oldVersion="0.0.0.0-6.0.0.0" newVersion="6.0.0.0" />
      </dependentAssembly>
      <dependentAssembly>
        <assemblyIdentity name="WebGrease" culture="neutral" publicKeyToken="31bf3856ad364e35" />
        <bindingRedirect oldVersion="0.0.0.0-1.5.2.14234" newVersion="1.5.2.14234" />
      </dependentAssembly>      
    </assemblyBinding>
  </runtime>
  <system.codedom>
    <compilers>
      <compiler language="c#;cs;csharp" extension=".cs" type="Microsoft.CodeDom.Providers.DotNetCompilerPlatform.CSharpCodeProvider, Microsoft.CodeDom.Providers.DotNetCompilerPlatform, Version=1.0.0.0, Culture=neutral, PublicKeyToken=31bf3856ad364e35" warningLevel="4" compilerOptions="/langversion:6 /nowarn:1659;1699;1701" />
      <compiler language="vb;vbs;visualbasic;vbscript" extension=".vb" type="Microsoft.CodeDom.Providers.DotNetCompilerPlatform.VBCodeProvider, Microsoft.CodeDom.Providers.DotNetCompilerPlatform, Version=1.0.0.0, Culture=neutral, PublicKeyToken=31bf3856ad364e35" warningLevel="4" compilerOptions="/langversion:14 /nowarn:41008 /define:_MYTYPE=\&quot;Web\&quot; /optionInfer+" />
    </compilers>
  </system.codedom>
</configuration>

UPDATE. As entradas de log do IIS para uma solicitação com falha são as seguintes:

2016-10-23 21:13:22 127.0.0.1 GET /MyWeb/MyPage.aspx - 80 - 127.0.0.1 Mozilla/5.0+(compatible;+MSIE+9.0;+Windows+NT+6.0;+WOW64;+Trident/5.0) 301 0 0 46
2016-10-23 21:13:22 127.0.0.1 GET /MyWeb/MyPage - 80 - 127.0.0.1 Mozilla/5.0+(compatible;+MSIE+9.0;+Windows+NT+6.0;+WOW64;+Trident/5.0) 404 0 2 0

Observe que existem duas entradas. O primeiro corresponde a MyPage.aspx , que é a página que solicitei digitando no campo URL. Isso resulta em um erro 301 (movido permanentemente). Imediatamente depois, há uma entrada para a mesma página sem a extensão .aspx , o que resulta em um erro 404 com o substatus 0. Não entendo por que a URL completa obtém um 301 e por que o servidor tenta entregar ( e falha) uma página sem a extensão.

UPDATE. Acabei de fazer uma experiência interessante. Eu criei um novo aplicativo da web no meu servidor, com um único arquivo Test.aspx . Funcionou como esperado, ou seja, o servidor entrega a página quando você a solicita explicitamente. Então eu copiei todo o conteúdo do site que está me dando dor de cabeça, e Test.aspx parou de funcionar! Em seguida, excluí tudo dessa Web, exceto o arquivo Test.aspx , e ele não voltou a funcionar, mas não deu certo. Em conclusão, há algo no conteúdo da Web que estraga tudo e que persiste após você excluir o conteúdo. Este é um site que criei com o Visual Studio 2015 usando um modelo de projeto que vem com o Bootstrap e algumas outras coisas. Estou completamente confuso.

    
por CesarGon 20.10.2016 / 11:34

1 resposta

2

Depois de muita pesquisa, encontrei uma solução para isso. Devo dizer que sei como resolver o problema, mas ainda não sei por que o problema ocorre.

O problema está relacionado ao mecanismo de "URLs amigáveis" que está disponível no IIS 7. Desativei eles alterando o código em App_Start\RouteConfig.cs de:

var settings = new FriendlyUrlSettings();
settings.AutoRedirectMode = RedirectMode.Permanent;
routes.EnableFriendlyUrls(settings);

para:

var settings = new FriendlyUrlSettings();
settings.AutoRedirectMode = RedirectMode.Off;
routes.EnableFriendlyUrls(settings);

Isso corrigiu o problema. Tanto quanto eu entendo, URLs amigáveis são sobre a queda de extensões de arquivo, e eu acho que é por isso que recebo o erro 301 e uma tentativa subseqüente de um arquivo sem extensão toda vez que eu solicito uma página. No entanto, não sei por que o IIS falha em entregar o arquivo.

De qualquer forma, está consertado agora. Obrigado a todos que ajudaram a diagnosticar o problema.

    
por 24.10.2016 / 19:17

Tags