IIS 7 не может обслуживать страницы .aspx, но работает с файлами по умолчанию

IIS 7 не может обслуживать страницы .aspx, но работает с файлами по умолчанию

Я развернул веб-сайт ASP.NET 4 на IIS 7 на Windows Server 2008. Когда я перехожу в корневую папку или любую другую папку на сайте, сервер отвечает, предоставляя страницу по умолчанию, Default.aspxкак и ожидалось. Однако, когда я запрашиваю определенную страницу с .aspxрасширением, я получаю ошибку 404.

Например, когда я запрашиваю:

http://localhost/MyWeb/

сервер успешно доставляет http://localhost/MyWeb/Default.aspx. Однако, если я явно запросил:

http://localhost/MyWeb/Default.aspx

затем IIS отвечает ошибкой 404.

Подробности ошибки следующие:

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

Очевидно, что .NET framework установлен и работает, поскольку я могу попасть на страницы по умолчанию. Кстати, я заметил, что когда сервер дает сбой и показывает страницу ошибки 404, URL, который я ввел (например, http://localhost/MyWeb/Default.aspx), теряет расширение (и читается как http://localhost/MyWeb/Default).

Я попробовал запустить aspnet_iisreg -iи перезапустить сервер, но ничего не изменилось.

Что я упускаю? Спасибо.

ОБНОВЛЕНИЕ. Я размещаю здесь web.configсвой сайт. Других файлов конфигурации, которые к нему относятся, нет.

<?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>

ОБНОВЛЕНИЕ. Записи журнала IIS для невыполненного запроса следующие:

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

Обратите внимание, что есть две записи. Первая соответствует MyPage.aspx, что является страницей, которую я запросил, введя ее в поле URL. Это приводит к ошибке 301 (перемещено навсегда). Сразу после этого есть запись для той же страницы без расширения .aspx, которая приводит к ошибке 404 с подстатусом 0. Я не понимаю, почему полный URL получает 301, и почему сервер затем пытается доставить (и терпит неудачу) страницу без расширения.

ОБНОВЛЕНИЕ. Я только что провел интересный эксперимент. Я создал новое веб-приложение на своем сервере, содержащее один Test.aspxфайл. Оно работало, как и ожидалось, то есть сервер доставляет страницу, когда вы явно запрашиваете ее. Затем я скопировал все содержимое с веб-сайта, который доставляет мне головную боль, и Test.aspxперестал работать! Затем я удалил все с этого сайта, кроме файла Test.aspx, и он не восстановился, а продолжал давать сбои. В заключение, есть что-то в веб-контенте, что все портит, и что сохраняется после удаления контента. Это веб-сайт, который я создал с помощью Visual Studio 2015, используя шаблон проекта, который поставляется с Bootstrap и несколькими другими вещами. Я совершенно запутался.

решение1

После долгих исследований я нашел решение этой проблемы. Должен сказать, что я знаю, как решить эту проблему, но я все еще не уверен, почему она возникает.

Проблема связана с механизмом «дружественных URL-адресов», доступным в IIS 7. Я отключил их, изменив код App_Start\RouteConfig.csс:

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

к:

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

Это исправило проблему. Насколько я понимаю, дружественные URL-адреса — это удаление расширений файлов, и я думаю, что именно поэтому я получаю ошибку 301 и последующую попытку файла без расширения каждый раз, когда я запрашиваю страницу. Однако я не знаю, почему IIS не может доставить файл.

В любом случае, теперь это исправлено. Спасибо всем, кто помог диагностировать проблему.

Связанный контент