我在做什么:
开放Visual Studio社区2015
File ->新建->项目
在Visual c#: Web -> ASP下。NET Web应用程序
Web应用程序
并按f5弹出错误“无法连接到web服务器'IIS Express'”。
删除applicationhost。config,位于Documents\IISExpress\config中,不会更改错误消息。(程序文件和程序文件(x86)中也有一个IISExpress文件夹。)
我注意到一件事,我不知道这是不是问题
引用文件'lib/jquery-validation/jquery.validate.js'未找到。
我有一堆破烂,但我没注意到里面有什么。这里有一些内容:
“框架”:{“框架”
我没有注意到问题,但我有网络数据,如果这可以帮助找出为什么我不能连接到web服务器。我立即得到一个RST,ACK,所以我猜端口是关闭的,不管这个web服务器是什么,没有被设置。
关于这个问题的更多信息:800700c1 error from /trace:error
我试过了:
删除applicationhost。配置(和更改端口号)
以管理员身份运行visual studio
删除文档中的IISExpress文件夹(更改错误消息,直到文件夹重新安装)
切换SSL关闭和打开,复制url到启动框。(注意:我没有使用ssl)
清除所有SFC /scannow错误
从x86版本和64位版本启动iisexpress
我不会假装完全理解MS bug造成的这个问题,但这里有另一个潜在的解决方案:
在.vs/config/applicationHost. conf文件中。在config文件中,找到<system.applicationHost><applicationPools>。在这些池下,确保managedRuntimeVersion属性值与系统的IIS配置中的值(和/或已安装的. net框架的版本)匹配。
例如,你可能会发现(正如我所做的)生成的文件有:
<add name="Clr4IntegratedAppPool" managedRuntimeVersion="v4.0" managedPipelineMode="Integrated" CLRConfigFile="%IIS_USER_HOME%\config\aspnet.config" autoStart="true" />
在我的例子中,你可以用:
<add name="Clr4IntegratedAppPool" managedRuntimeVersion="v4.0.30319" managedPipelineMode="Integrated" CLRConfigFile="%IIS_USER_HOME%\config\aspnet.config" autoStart="true" />
注意从“v4.0”到“v4.0.30319”的替换。这就解决了问题。
发生了什么:
我相信VS正在生成一个applicationHost。. net框架的“默认”版本,这可能与系统上安装/配置的特定版本不匹配。您可以通过跟踪Process Monitor中的执行来调试/观察这个问题,并找到iisexpress.exe的命令行。在添加/trace:error的情况下运行此命令,将得到一个关于预装版本为v4.0的CLR失败的信息更丰富的消息。即:
启动IIS Express…
尝试预加载CLR版本v4.0时失败。Hr = 80131700
W3WP_HOST hr = 80131700初始化失败
过程模型关闭称为
无法启动iisexpress。
不管怎样,我觉得这可能会对其他人有所帮助,因为在网上有多个含有坏信息的推荐信是很常见的,我个人现在已经碰到过几次了。
请确保下列注册表项\HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\HTTP\Parameters\ListenOnlyList不包含未绑定到您机器上已启用的网络适配器的IP地址。
这是我在尝试了这个SO问题中列出的各种其他解决方案后出现问题的原因,例如:
删除applicationhost.config
打开和关闭SSL。
修改端口号。
手动关闭IIS Express进程。
重新安装IIS Express。
修复Visual Studio。
安装新版本的Visual Studio
创建一个新的。net框架Web应用程序。
创建一个新的。net核心Web应用程序。
执行netsh urlacl命令
运行netsh http add iplisten ipaddress=::
以管理员身份运行Visual Studio。
确保旁路遍历权应用..
显然,当IIS express试图启动时,它正在尝试绑定到这个无效的IP。解决办法是删除无效的IP。这个额外的无效可能来自我的家庭无线网络,而在工作中,我通过硬连线适配器分配了一个不同的IP。
一个全面的解决方案可能是删除注册表项中的所有ip,然后运行netsh http add iplisten ipaddress=::命令允许监听所有地址。
在注意到以下事件日志条目后,我能够追踪到这个问题:
IIS Express: The worker process for app pool 'WebApplicationNetCore AppPool',
PID='23260', failed to initialize the http.sys communication when
asked to start processing http requests and therefore will be
considered ill by W3SVC and terminated. The data field contains the
error number.
IIS Express: The worker process failed to initialize correctly and
therefore could not be started. The data is the error.
HTTP Event: Unable to bind to the underlying transport for 192.168.1.42:52999. The IP Listen-Only list may contain a reference to an interface
which may not exist on this machine. The data field contains the
error number.