Я развернул веб-сайт 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=\"Web\" /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, и некоторые другие вещи. Я совершенно сбит с толку.