Visual Studio ASP.NET 核心调试 IIS Express - 无法访问站点
Visual Studio ASP.NET Core Debug IIS Express - Site can't be reached
我一直在 Windows 10 PC 上开发 VS 2019 中的 ASP.NET Core 2.1 Web 应用程序。一切正常,在 Chrome/IIS Express 中调试没有问题。
我将我的项目复制到我刚开始使用的新 Win 10 计算机上。
当我尝试在 Chrome 中使用 IIS Express 调试项目时,我收到一个错误页面:无法访问此站点。
我遵循了 Overflow 文章中的各种建议修复方法,但似乎没有任何效果。这让我发疯,浪费了很多时间。我已经尝试了所有这些步骤,但没有成功:
- 禁用防病毒软件firewall/protection
- 检查项目属性(与以前的 PC 相同)
- 检查 launchSettings.json 文件(与之前的 PC 相同)
- 删除 vs/config 文件夹中的 applicationhost.config(post 表示此文件将在重建时重新创建,但重建后文件仍然不存在!)
- 删除 obj 文件夹并重建
- 删除 vs 文件夹并重建
- 检查 Windows 功能(与运行良好的旧 PC 相同)
- 更改 VS Options/Debugging:取消选中“启用编辑并继续”复选框
- 运行 cmd 管理员身份:cd "C:\Program Files (x86)\IIS Express"
IisExpressAdminCmd.exe setupsslUrl -url:https://localhost:44301/ -UseSelfSigned
launchSettings.json 文件
launchSettings.json
{
"iisSettings": {
"windowsAuthentication": true,
"anonymousAuthentication": true,
"iisExpress": {
"applicationUrl": "https://localhost:44301/",
"sslPort": 44376
}
},
"profiles": {
"IIS Express": {
"commandName": "IISExpress",
"launchBrowser": true,
"environmentVariables": {
"ASPNETCORE_ENVIRONMENT": "Development"
}
},
"CanvasWeb": {
"commandName": "Project",
"launchBrowser": true,
"environmentVariables": {
"ASPNETCORE_ENVIRONMENT": "Development"
},
"applicationUrl": "http://localhost:61900/"
}
}
}
更新
我尝试了以下操作但仍未解决问题:
- 运行修复IIS Express
- 检查证书库中没有重复的证书
- 已删除证书以使 IIS 生成新证书
- 创建了一个新的“测试”项目 - 出现同样的问题
问题可能是 IIS Express 的 HTTPS 错误。
检查它:
创建一个没有 Https 的新 ASP.NET 核心 Web 应用程序。
在 Web 应用程序模板中取消选中/取消选择为 https 配置
Uncheck configure for https
如果新的 Web 应用程序运行,则为 IIS Express HTTPS 问题。
运行 流动的力量 shell 管理员 previliadge 代码将解决 IIS Express 问题。
# code start
Start-Transcript -Path "$($MyInvocation.MyCommand.Path).log"
try {
Write-Host "Creating cert resources"
$ekuOidCollection = [System.Security.Cryptography.OidCollection]::new();
$ekuOidCollection.Add([System.Security.Cryptography.Oid]::new("1.3.6.1.5.5.7.3.1","Server Authentication")) | Out-Null
$sanBuilder = [System.Security.Cryptography.X509Certificates.SubjectAlternativeNameBuilder]::new();
$sanBuilder.AddDnsName("localhost") | Out-Null
Write-Host "Creating cert extensions"
$certificateExtensions = @(
# Subject Alternative Name
$sanBuilder.Build($true),
# ASP.NET Core OID
[System.Security.Cryptography.X509Certificates.X509Extension]::new(
"1.3.6.1.4.1.311.84.1.1",
[System.Text.Encoding]::ASCII.GetBytes("IIS Express Development Certificate"),
$false),
# KeyUsage
[System.Security.Cryptography.X509Certificates.X509KeyUsageExtension]::new(
[System.Security.Cryptography.X509Certificates.X509KeyUsageFlags]::KeyEncipherment,
$true),
# Enhanced key usage
[System.Security.Cryptography.X509Certificates.X509EnhancedKeyUsageExtension]::new(
$ekuOidCollection,
$true),
# Basic constraints
[System.Security.Cryptography.X509Certificates.X509BasicConstraintsExtension]::new($false,$false,0,$true)
)
Write-Host "Creating cert parameters"
$parameters = @{
Subject = "localhost";
KeyAlgorithm = "RSA";
KeyLength = 2048;
CertStoreLocation = "Cert:\LocalMachine\My";
KeyExportPolicy = "Exportable";
NotBefore = Get-Date;
NotAfter = (Get-Date).AddYears(1);
HashAlgorithm = "SHA256";
Extension = $certificateExtensions;
SuppressOid = @("2.5.29.14");
FriendlyName = "IIS Express Development Certificate"
}
Write-Host "Creating cert"
$cert = New-SelfSignedCertificate @parameters
$rootStore = New-Object System.Security.Cryptography.X509Certificates.X509Store -ArgumentList Root, LocalMachine
$rootStore.Open("MaxAllowed")
$rootStore.Add($cert)
$rootStore.Close()
Write-Host "Creating port bindings"
# Add an Http.Sys binding for port 44300-44399
$command = 'netsh'
for ($i=44300; $i -le 44399; $i++) {
$optionsDelete = @('http', 'delete', 'sslcert', "ipport=0.0.0.0:$i")
$optionsAdd = @('http', 'add', 'sslcert', "ipport=0.0.0.0:$i", "certhash=$($cert.Thumbprint)", 'appid={214124cd-d05b-4309-9af9-9caa44b2b74a}')
Write-Host "Running $command $optionsDelete"
& $command $optionsDelete
Write-Host "Running $command $optionsAdd"
& $command $optionsAdd
}
}
catch {
Write-Error $_.Exception.Message
}
finally {
Stop-Transcript
}
# code End
我确实遇到了这个问题,并在互联网上进行了一些研究,但是找不到解决方案。然后,我决定关闭我的防病毒软件 (Kaspersky Internet Security 21.2) 并检查它是否能解决问题,之后一切都开始工作了!不幸的是,我找不到负责网络 activity 的防病毒设置,所以即使现在,如果我在 .NET 中测试后端 API,我也必须关闭防病毒一段时间((
我一直在 Windows 10 PC 上开发 VS 2019 中的 ASP.NET Core 2.1 Web 应用程序。一切正常,在 Chrome/IIS Express 中调试没有问题。
我将我的项目复制到我刚开始使用的新 Win 10 计算机上。
当我尝试在 Chrome 中使用 IIS Express 调试项目时,我收到一个错误页面:无法访问此站点。
我遵循了 Overflow 文章中的各种建议修复方法,但似乎没有任何效果。这让我发疯,浪费了很多时间。我已经尝试了所有这些步骤,但没有成功:
- 禁用防病毒软件firewall/protection
- 检查项目属性(与以前的 PC 相同)
- 检查 launchSettings.json 文件(与之前的 PC 相同)
- 删除 vs/config 文件夹中的 applicationhost.config(post 表示此文件将在重建时重新创建,但重建后文件仍然不存在!)
- 删除 obj 文件夹并重建
- 删除 vs 文件夹并重建
- 检查 Windows 功能(与运行良好的旧 PC 相同)
- 更改 VS Options/Debugging:取消选中“启用编辑并继续”复选框
- 运行 cmd 管理员身份:cd "C:\Program Files (x86)\IIS Express" IisExpressAdminCmd.exe setupsslUrl -url:https://localhost:44301/ -UseSelfSigned
launchSettings.json 文件
launchSettings.json
{
"iisSettings": {
"windowsAuthentication": true,
"anonymousAuthentication": true,
"iisExpress": {
"applicationUrl": "https://localhost:44301/",
"sslPort": 44376
}
},
"profiles": {
"IIS Express": {
"commandName": "IISExpress",
"launchBrowser": true,
"environmentVariables": {
"ASPNETCORE_ENVIRONMENT": "Development"
}
},
"CanvasWeb": {
"commandName": "Project",
"launchBrowser": true,
"environmentVariables": {
"ASPNETCORE_ENVIRONMENT": "Development"
},
"applicationUrl": "http://localhost:61900/"
}
}
}
更新
我尝试了以下操作但仍未解决问题:
- 运行修复IIS Express
- 检查证书库中没有重复的证书
- 已删除证书以使 IIS 生成新证书
- 创建了一个新的“测试”项目 - 出现同样的问题
问题可能是 IIS Express 的 HTTPS 错误。 检查它: 创建一个没有 Https 的新 ASP.NET 核心 Web 应用程序。 在 Web 应用程序模板中取消选中/取消选择为 https 配置 Uncheck configure for https
如果新的 Web 应用程序运行,则为 IIS Express HTTPS 问题。 运行 流动的力量 shell 管理员 previliadge 代码将解决 IIS Express 问题。
# code start
Start-Transcript -Path "$($MyInvocation.MyCommand.Path).log"
try {
Write-Host "Creating cert resources"
$ekuOidCollection = [System.Security.Cryptography.OidCollection]::new();
$ekuOidCollection.Add([System.Security.Cryptography.Oid]::new("1.3.6.1.5.5.7.3.1","Server Authentication")) | Out-Null
$sanBuilder = [System.Security.Cryptography.X509Certificates.SubjectAlternativeNameBuilder]::new();
$sanBuilder.AddDnsName("localhost") | Out-Null
Write-Host "Creating cert extensions"
$certificateExtensions = @(
# Subject Alternative Name
$sanBuilder.Build($true),
# ASP.NET Core OID
[System.Security.Cryptography.X509Certificates.X509Extension]::new(
"1.3.6.1.4.1.311.84.1.1",
[System.Text.Encoding]::ASCII.GetBytes("IIS Express Development Certificate"),
$false),
# KeyUsage
[System.Security.Cryptography.X509Certificates.X509KeyUsageExtension]::new(
[System.Security.Cryptography.X509Certificates.X509KeyUsageFlags]::KeyEncipherment,
$true),
# Enhanced key usage
[System.Security.Cryptography.X509Certificates.X509EnhancedKeyUsageExtension]::new(
$ekuOidCollection,
$true),
# Basic constraints
[System.Security.Cryptography.X509Certificates.X509BasicConstraintsExtension]::new($false,$false,0,$true)
)
Write-Host "Creating cert parameters"
$parameters = @{
Subject = "localhost";
KeyAlgorithm = "RSA";
KeyLength = 2048;
CertStoreLocation = "Cert:\LocalMachine\My";
KeyExportPolicy = "Exportable";
NotBefore = Get-Date;
NotAfter = (Get-Date).AddYears(1);
HashAlgorithm = "SHA256";
Extension = $certificateExtensions;
SuppressOid = @("2.5.29.14");
FriendlyName = "IIS Express Development Certificate"
}
Write-Host "Creating cert"
$cert = New-SelfSignedCertificate @parameters
$rootStore = New-Object System.Security.Cryptography.X509Certificates.X509Store -ArgumentList Root, LocalMachine
$rootStore.Open("MaxAllowed")
$rootStore.Add($cert)
$rootStore.Close()
Write-Host "Creating port bindings"
# Add an Http.Sys binding for port 44300-44399
$command = 'netsh'
for ($i=44300; $i -le 44399; $i++) {
$optionsDelete = @('http', 'delete', 'sslcert', "ipport=0.0.0.0:$i")
$optionsAdd = @('http', 'add', 'sslcert', "ipport=0.0.0.0:$i", "certhash=$($cert.Thumbprint)", 'appid={214124cd-d05b-4309-9af9-9caa44b2b74a}')
Write-Host "Running $command $optionsDelete"
& $command $optionsDelete
Write-Host "Running $command $optionsAdd"
& $command $optionsAdd
}
}
catch {
Write-Error $_.Exception.Message
}
finally {
Stop-Transcript
}
# code End
我确实遇到了这个问题,并在互联网上进行了一些研究,但是找不到解决方案。然后,我决定关闭我的防病毒软件 (Kaspersky Internet Security 21.2) 并检查它是否能解决问题,之后一切都开始工作了!不幸的是,我找不到负责网络 activity 的防病毒设置,所以即使现在,如果我在 .NET 中测试后端 API,我也必须关闭防病毒一段时间((