Implantei um site 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
conforme o esperado. No entanto, quando solicito uma página específica com .aspx
extensão, recebo um erro 404.
Por exemplo, quando 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
então 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
).
Tentei executar aspnet_iisreg -i
e reiniciar o servidor, mas as coisas não mudaram.
o que estou perdendo? Obrigado.
ATUALIZAR. 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=\"Web\" /optionInfer+" />
</compilers>
</system.codedom>
</configuration>
ATUALIZAR. 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 .aspx
extensão, o que resulta em um erro 404 com substatus 0. Não entendo por que o URL completo recebe 301 e por que o servidor tenta entregar (e falha) uma página sem a extensão.
ATUALIZAR. Acabei de realizar uma experiência interessante. Criei uma nova aplicação web no meu servidor, possuindo um único Test.aspx
arquivo. Funcionou conforme o esperado, ou seja, o servidor entrega a página quando você solicita explicitamente. Aí copiei todo o conteúdo do site que está me dando dor de cabeça e Test.aspx
parei de funcionar! Então, apaguei tudo desta web, exceto o Test.aspx
arquivo, e ele não voltou a funcionar, mas continuou falhando. Concluindo, há algo no conteúdo da web que bagunça tudo e que persiste depois que você exclui 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 totalmente confuso.
Responder1
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" disponível no IIS 7. Eu os desativei alterando o código 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. Pelo que entendi, URLs amigáveis tratam de descartar extensões de arquivo, e acho que é por isso que recebo o erro 301 e uma tentativa subsequente de um arquivo sem extensão sempre que solicito uma página. No entanto, não sei por que o IIS não consegue entregar o arquivo.
De qualquer forma, está consertado agora. Obrigado a todos que ajudaram a diagnosticar o problema.