这让整个团队疯狂。 IIS或我们的Web服务器必须有一些简单的错误配置部分,但每次我们尝试在IIS 7.5上运行ASP.NET Web应用程序时,都会出现以下错误...
这是完整的错误:
HTTP Error 500.19 - Internal Server Error
The requested page cannot be accessed because the related configuration
data for the page is invalid.
`Detailed Error Information`
Module IIS Web Core
Notification Unknown
Handler Not yet determined
Error Code 0x8007000d
Config Error
Config File \\?\E:\wwwroot\web.config
Requested URL http://localhost:80/Default.aspx
Physical Path
Logon Method Not yet determined
Logon User Not yet determined
Config Source
-1:
0:
该计算机正在运行Windows Server 2008 R2。我们正在使用Visual Studio 2008开发Web应用程序。
根据Microsoft的代码8007000d意味着我们的web.config中存在语法错误 - 除了项目构建并在本地运行良好。查看XML Notepad中的web.config也不会出现任何语法错误。我假设我必须是某种糟糕的配置...?
有谁知道我可能会在哪里找到有关错误的更多信息?在EventViewer中没有显示任何内容:(
不确定还有什么有用的提及......
非常感谢协助。谢谢!
更新! - 发布WEB.CONFIG以下
好的,因为我发布了上面的原始问题,我已经跟踪了导致错误的web.config中的精确行。
这是线(它们出现在<System.webServer>
标签之间)......
<httpHandlers>
<remove verb="*" path="*.asmx"/>
<add verb="*" path="*.asmx" validate="false" type="System.Web.Script.Services.ScriptHandlerFactory, System.Web.Extensions, Version=1.0.61025.0, Culture=neutral, PublicKeyToken=f2cb5667dc123a56"/>
</httpHandlers>
注意:如果我删除<httpHandlers>
之间的行我仍然得到错误。我真的必须删除<httpHandlers>
(和中间的行)以停止上面的错误。
一旦我完成了这个,我得到一个新的500.19错误。值得庆幸的是,这次IIS实际上告诉我web.config的哪一位导致了问题...
<handlers>
<remove name="WebServiceHandlerFactory-Integrated"/>
<add verb="*" path="*.asmx" validate="false" type="System.Web.Script.Services.ScriptHandlerFactory,System.Web.Extensions, Version=1.0.61025.0, Culture=neutral, PublicKeyToken=f2cb5667dc123a56"/>
<add name="ScriptHandlerFactoryAppServices" verb="*" path="*_AppService.axd" preCondition="integratedMode" type="System.Web.Script.Services.ScriptHandlerFactory, System.Web.Extensions, Version=1.0.61025.0, Culture=neutral, PublicKeyToken=f2cb5667dc123a56"/>
<add name="ScriptResource" preCondition="integratedMode" verb="GET,HEAD" path="ScriptResource.axd" type="System.Web.Handlers.ScriptResourceHandler, System.Web.Extensions, Version=1.0.61025.0, Culture=neutral, PublicKeyToken=f2cb5667dc123a56"/>
</handlers>
看看这些行,很明显问题已经在同一个<system.webServer>
标签中进一步迁移到<handlers>
标签。
新错误也更明确,并且特别抱怨它无法识别属性“validate”(如上面第三行所示)。删除此属性然后使其抱怨相同的行没有所需的“name”属性。添加此属性然后会出现ASP.NET错误...
无法加载文件或程序集'System.web.Extensions,Version = 1.0.61025.0,Culture = neutral,PublicKeyToken = f2cb5667dc123a56'或其依赖项之一。该系统找不到指定的文件。
显然我认为这些新错误刚出现在我首先删除<httpHandlers>
标签 - 应用程序显然需要它们 - 所以问题仍然存在:为什么这些标签会在IIS中首先出现错误???
我是否需要在IIS上安装一些东西才能使它与它们一起使用?
再次感谢任何帮助。
WEB.CONFIG
这是我们web.Config的麻烦......我希望这可以帮助别人找到我们的问题!
<system.Web>
<!-- stuff cut out -->
<httpHandlers>
<remove verb="*" path="*.asmx"/>
<add verb="*" path="*.asmx" validate="false" type="System.Web.Script.Services.ScriptHandlerFactory, System.Web.Extensions, Version=1.0.61025.0, Culture=neutral, PublicKeyToken=f2cb5667dc123a56"/>
<add verb="*" path="*_AppService.axd" validate="false" type="System.Web.Script.Services.ScriptHandlerFactory, System.Web.Extensions, Version=1.0.61025.0, Culture=neutral, PublicKeyToken=f2cb5667dc123a56"/>
<add verb="GET,HEAD" path="ScriptResource.axd" type="System.Web.Handlers.ScriptResourceHandler, System.Web.Extensions, Version=1.0.61025.0, Culture=neutral, PublicKeyToken=f2cb5667dc123a56" validate="false"/>
</httpHandlers>
<httpModules>
<add name="ScriptModule" type="System.Web.Handlers.ScriptModule, System.Web.Extensions, Version=1.0.61025.0, Culture=neutral, PublicKeyToken=f2cb5667dc123a56"/>
</httpModules>
</system.web>
<system.webServer>
<validation validateIntegratedModeConfiguration="false"/>
<modules>
<add name="ScriptModule" preCondition="integratedMode" type="System.Web.Handlers.ScriptModule, System.Web.Extensions, Version=1.0.61025.0, Culture=neutral, PublicKeyToken=f2cb5667dc123a56"/>
</modules>
<remove verb="*" path="*.asmx"/>
<add verb="*" path="*.asmx" validate="false" type="System.Web.Script.Services.ScriptHandlerFactory, System.Web.Extensions, Version=1.0.61025.0, Culture=neutral, PublicKeyToken=f2cb5667dc123a56"/>
<handlers>
<remove name="WebServiceHandlerFactory-Integrated"/>
<add verb="*" path="*.asmx" validate="false" type="System.Web.Script.Services.ScriptHandlerFactory,System.Web.Extensions, Version=1.0.61025.0, Culture=neutral, PublicKeyToken=f2cb5667dc123a56"/>
<add name="ScriptHandlerFactoryAppServices" verb="*" path="*_AppService.axd" preCondition="integratedMode" type="System.Web.Script.Services.ScriptHandlerFactory, System.Web.Extensions, Version=1.0.61025.0, Culture=neutral, PublicKeyToken=f2cb5667dc123a56"/>
<add name="ScriptResource" preCondition="integratedMode" verb="GET,HEAD" path="ScriptResource.axd" type="System.Web.Handlers.ScriptResourceHandler, System.Web.Extensions, Version=1.0.61025.0, Culture=neutral, PublicKeyToken=f2cb5667dc123a56"/>
</handlers>
</system.webServer>
我有这些确切的症状,我的问题与彼得的相似。是否在新服务器上设置现有项目。我的项目引用了IIS7 URL重写模块,但尚未在新服务器上安装。安装它解决了我的问题。
您可以使用Microsoft Web Platform Installer进行安装。执行它,选择Products,在左侧菜单中选择Server并在列表中找到URL Rewrite并安装它。
或者你可以下载它here。
就我而言,.NET Core Windows Hosting Bundle安装有问题。
我已安装并在安装后使用(“net stop was / y”和“net start w3svc”)重新启动了IIS,但是我会得到错误代码0x8007000d和Config Source -1:0:的500.19错误。
我设法通过修复.NET Core Windows Hosting Bundle安装并使用上面提到的命令重新启动IIS来解决此问题。
希望这有助于某人!
这可能与否有关....我从上面提到的相同错误,开始谷歌搜索,进行更改,获得新错误,无限循环开始。
由于该错误而导致的更改是在服务器的“管理”部分下的IIS管理器中的功能委派中弄乱了。对不起,我不记得我改变了哪一个,但谷歌搜索可能有所帮助。
这让我超越了第一个错误成为一个完整的新流,其中一些完全没有意义。 (在虚拟目录下运行时会出现一个错误,将其转换为应用程序会产生另一个错误,etec等)。最终解决了这一系列错误的是:IIS管理器,应用程序池,DefaultAppPool,启用32位应用程序= True
我在一个32位的Windows xp盒子上启动了这个应用程序,现在我在64位Windows 7机器上运行它。
所以希望这有助于其他人。
我的IIS 7.5不理解web.config中的标记在VS 2010中,它也标记了该标记。检查配置文件是否准确,找到所有带下划线的标签。我把它放在评论中,错误就消失了。
在web.config文件中注释以下行。
<modules>
<!--<add name="ScriptModule" preCondition="integratedMode" type="System.Web.Handlers.ScriptModule, System.Web.Extensions, Version=1.0.61025.0, Culture=neutral, PublicKeyToken=31bf3856ad364e35"/>-->
</modules>
<handlers>
<remove name="WebServiceHandlerFactory-ISAPI-2.0"/>
<!--<add name="ScriptHandlerFactory" verb="*" path="*.asmx" preCondition="integratedMode" type="System.Web.Script.Services.ScriptHandlerFactory, System.Web.Extensions, Version=1.0.61025.0, Culture=neutral, PublicKeyToken=31bf3856ad364e35"/>
<add name="ScriptResource" verb="GET" path="ScriptResource.axd" type="System.Web.Handlers.ScriptResourceHandler, System.Web.Extensions, Version=1.0.61025.0, Culture=neutral, PublicKeyToken=31bf3856ad364e35"/>-->
</handlers>
这会奏效。
我有同样的错误。我有一个.net框架版本2.0的IIS站点,但我的应用程序需要4.0。我改变了版本并且它有效。
如果有人可能有同样的问题,则发布提醒。
这个可爱的详细错误仍然存在于2019年!我只想补充一点,如果您的web.config
有效且可访问,则很可能是依赖性问题。
正如OP所提到的,它是一个AJAX
模块,并且正如其他人通常使用的Rewrite
模块。只需在web.config中睁大眼睛,你的标签引用了哪些模块和库,因为错误代码0x8007000d可能与任何依赖关系有关。
在我的情况下,我没有意识到AspNetCore
包丢失,必须安装!很高兴我发现这篇文章!!
我在Windows 7中遇到了同样的问题。
解决方案是转到基本设置>连接为>特定用户 - 并以用户身份登录,而不是默认的“传递”
这为我解决了这个问题。
Windows 7的
试试这个,
以管理员身份运行cmd。
Unistall all iis。
start /w pkgmgr.exe /uu:IIS-WebServerRole;WAS-WindowsActivationService
重新安装iis和normaly它的工作
阿兰
我把<customErrors>
标签放在<system.webServer>
里面而不是它所属的<system.web>
时得到了这个错误。在<customErrors>
标签下有一点点波浪,但我没有马上注意到它。
在新机器上与这一天斗争了一天后,我遇到了以下链接。我错过了重写模块。这解决了一切。
http://forums.iis.net/t/1176834.aspx
http://learn.iis.net/page.aspx/460/using-the-url-rewrite-module/
啊哈!我打败了这个问题!我的上帝,对于像我这样有限的IIS经验的人来说,这是一个野兽。我真的以为我会花一整个周末来修理它。
这是解决这个邪恶问题的其他任何人的解决方案。
首先要注意的是:如果您希望这是您的解决方案,请确保您具有相同的错误代码(0x8007000d)和配置源(-1:0 :)。如果没有,这不是你的解决方案。
接下来要注意的是:在web.config中没有正确安装AJAX!
按照本指南修复此问题: http://www.asp.net/AJAX/documentation/live/ConfiguringASPNETAJAX.aspx
然后,从以下链接在生产服务器上安装AJAX 1.0扩展:
http://www.asp.net/ajax/downloads/archive/ 更新:微软似乎已删除上述页面:(
而已!
遇到与上面相同的问题,相同的错误代码等。在Windows上设置本地网站8.经过多次搜索后发现我们缺少URL重写。下载后一切都很好。 :)
Server 2016上的相同问题,IIS 10,500.19错误。我安装了重定向模块,它工作正常。我不知道为什么默认不包括这个。
https://www.iis.net/downloads/microsoft/url-rewrite#additionalDownloads
要清楚它看起来像IIS 7中的web.config可以工作,或者设计工作,但缺少这个模块给出了真正奇怪和无益的错误。谷歌搜索将您带到一个Microsoft页面,该页面坚持您的网站已损坏或您的web.config已损坏。似乎都不是这样。
我只是添加一个答案,因为我花了几个小时试图解决相同的症状(但不同的问题):
可能的原因是64位应用程序池中的x86 dll,解决方案是在应用程序池设置中启用32位应用程序。
对我来说,为iis重新注册asp.net就可以了。希望这有助于其他人。
aspnet_regiis.exe -i
总结基于这里和其他地方的答案:
另一种无缘无故地获得500.19错误的方法是 - 缺少目录和/或破坏它们的权限。
如果遇到这个问题,我相信这个问题会询问完整的IIS版本。我假设这是因为这一行:
Config File \\?\E:\wwwroot\web.config
IIS安装程序通常会为您创建wwwroot
,这是所有网站的默认根文件夹和虚拟目录的挂载点。它总是存在,所以没问题,你通常不太关心它。
由于web.config文件是分层的,您可以在那里放置一个主web.config文件并在那里有一些root设置,所有站点都将继承它。 IIS检查该文件是否存在并尝试加载它。
然而,第一个有趣的部分:
如果已正确安装IIS,则此目录将存在。如果它不存在,您将得到500级错误。但是,如果您使用文件/目录权限,尤其是“高级”权限,您实际上可能会意外拒绝IIS服务帐户扫描/读取此目录的内容。如果IIS无法检查是否存在wwwroot \ web.config,或者它是否存在且IIS无法打开并读取它 - bam - 500-class错误。
但是,对于完整的IIS,它是不太可能的。使用完整IIS的开发人员/管理员通常不愿意使用wwwroot
,因此它通常保持正确配置。
通常,IIS Express“正常工作”。通常,使用IIS Express的开发人员通常不知道它内部有多少类似于真正的IIS。
您可以轻易地发现IIS Express有自己的applicationHost.config文件,并且VS为您创建和管理它(正确地,在某种程度上),并且那种令人大开眼界的人告诉您这不是那么简单和点 - 然后点击一下。
除了该配置文件,VisualStudio还在Documents
文件夹下创建一个空目录结构。如果我没记错的话,IIS Express会将这些文件夹视为您的网站的根目录,其上安装了包含您代码的虚拟目录。
稍后,就像IIS一样,当IIS Express启动时,它希望这些文件夹存在并检查那里的根web.config文件。站点web.config文件。几乎总是,这些web.config文件丢失了 - 这没关系,因为你不需要它们 - 你有你的**应用程序web.config“,它们被放置在虚拟目录中的其余内容中。
现在,第二个有趣的部分是:IIS Express期望空目录。它们可以是空的,但它们需要存在。如果它们不存在 - 您将收到500级错误,告诉您无法访问该路径上的“web.config”文件。
我第一次碰到这个问题的时候是我清理硬盘的时候。我发现'documents \ websites'文件夹,里面装满了垃圾,我认出了几个已经不再工作的项目了,全是空的,不是单个文件,所以我把它全部删了。一周后 - bam - 我无法运行/调试我目前正在工作的任何网站。错误是500.19,无法读取配置文件。
因此,如果您使用IIS Express并查看有关读取配置的500级错误,请仔细检查错误消息并阅读所有提到的路径。如果你看到类似的东西:
c:\users\user\documents\visual studio 2013\projects\WebProject1\WebProject1.web\web.config
c:\users\zeshan.munir\documents\visual studio 2015\projects\WebProject1\WebProject1.web\web.config
c:\users\zeshan.munir\documents\visual studio 2017\projects\WebProject1\WebProject1.web\web.config
etc..
去那里错误指示的位置,确保这些文件夹存在,确保IIS工作者帐户可以遍历和读取它们,如果您发现任何错误,也许就是这样。
BTW。在VisualStudio中,在ProjectProperties / Web上有一个“创建虚拟目录”按钮。它本质上是这样做的,所以你可以先尝试一下,但是IIRC它也可以在applicationHost.config文件中清除/覆盖/交换配置部分,所以如果你有任何自定义设置,请小心使用该按钮。