ExtensionlessUrlHandler和"递归太深;堆栈溢出"

时间:2016-02-03 15:36:20

标签: asp.net-web-api url-routing stack-overflow iis-express

我试图让一个开发人员的应用在我的机器上工作。解决方案是使用Web API在VS 2015中构建的,我使用64位IIS Express运行它。每个请求都返回500.0错误。请求跟踪日志说明了这一点:

1517.  -MODULE_SET_RESPONSE_ERROR_STATUS 
ModuleName    ManagedPipelineHandler 
Notification  EXECUTE_REQUEST_HANDLER 
HttpStatus    500 
HttpReason    Internal Server Error 
HttpSubStatus 0 
ErrorCode     Recursion too deep; the stack overflowed. (0x800703e9) 
ConfigExceptionInfo

相关配置部分如下所示:

<system.webServer>
<handlers>
  <remove name="OPTIONS" />
  <remove name="OPTIONSVerbHandler" />
  <remove name="TRACEVerbHandler" />
  <remove name="ExtensionlessUrlHandler-Integrated-4.0" />
  <remove name="ExtensionlessUrlHandler-ISAPI-4.0_32bit" />
  <remove name="ExtensionlessUrlHandler-ISAPI-4.0_64bit" />
  <add name="ExtensionlessUrlHandler-ISAPI-4.0_32bit" path="*" verb="*" modules="IsapiModule" scriptProcessor="%windir%\Microsoft.NET\Framework\v4.0.30319\aspnet_isapi.dll" preCondition="classicMode,runtimeVersionv4.0,bitness32" responseBufferLimit="0" />
  <add name="ExtensionlessUrlHandler-ISAPI-4.0_64bit" path="*" verb="*" modules="IsapiModule" scriptProcessor="%windir%\Microsoft.NET\Framework64\v4.0.30319\aspnet_isapi.dll" preCondition="classicMode,runtimeVersionv4.0,bitness64" responseBufferLimit="0" />
  <add name="ExtensionlessUrlHandler-Integrated-4.0" path="*" verb="*" type="System.Web.Handlers.TransferRequestHandler" preCondition="integratedMode,runtimeVersionv4.0" />
</handlers>
</system.webServer>

其他可能相关的事实:

  • 以前这台机器还没有用于网络托管,但我已经做了很多VS2013开发,上周只安装了2015年来运行这个项目。
  • 该项目确实包含一些C#6.0功能,即新的字符串插值功能。

我怎么会开始调试这个?我在谷歌上获得了相关的点击率。

2 个答案:

答案 0 :(得分:0)

改变路径=&#34; *&#34; to path =&#34; *。&#34;在您列出的每个处理程序中。

<add name="ExtensionlessUrlHandler-ISAPI-4.0_32bit" path="*." verb="*" modules="IsapiModule" scriptProcessor="%windir%\Microsoft.NET\Framework\v4.0.30319\aspnet_isapi.dll" preCondition="classicMode,runtimeVersionv4.0,bitness32" responseBufferLimit="0" />
<add name="ExtensionlessUrlHandler-ISAPI-4.0_64bit" path="*." verb="*" modules="IsapiModule" scriptProcessor="%windir%\Microsoft.NET\Framework64\v4.0.30319\aspnet_isapi.dll" preCondition="classicMode,runtimeVersionv4.0,bitness64" responseBufferLimit="0" />
<add name="ExtensionlessUrlHandler-Integrated-4.0" path="*." verb="*" type="System.Web.Handlers.TransferRequestHandler" preCondition="integratedMode,runtimeVersionv4.0" />

我相信有一种方法可以使用path =&#34; &#34;但我还没弄清楚它是什么。我刚碰到这个问题,因为我试图使用path =&#34; &#34;那个&#34;递归太深了......&#34;错误被抛出。

答案 1 :(得分:0)

将项目迁移到VS2017时(在VS2010中工作),我遇到了完全相同的问题,并设法通过遵循另一篇文章的建议来解决此问题:

https://stackoverflow.com/a/29370225

因此,问题在于IISExpress使用的是与IIS不同的处理程序名称(不带“ Handler”后缀),因此您需要将以下删除脚本添加到web.config中:

<!--Handler in IIS-->
<remove name="ExtensionlessUrlHandler-ISAPI-4.0_32bit"/>
<remove name="ExtensionlessUrlHandler-ISAPI-4.0_64bit"/>
<remove name="ExtensionlessUrlHandler-Integrated-4.0"/>
<!--Handler in IISExpress-->
<remove name="ExtensionlessUrl-ISAPI-4.0_32bit" />
<remove name="ExtensionlessUrl-Integrated-4.0" />

希望这会有所帮助。