2.6 KiB
title | author | description | monikerRange | ms.author | ms.custom | ms.date | no-loc | uid | ||||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
Use ASP.NET Core with HTTP/3 on IIS | tratcher | Learn how to use HTTP/3 features with IIS. | >= aspnetcore-6.0 | chrross | mvc | 09/09/2021 |
|
host-and-deploy/iis/http3 |
Use ASP.NET Core with HTTP/3 on IIS
By Chris Ross
HTTP/3 is supported with ASP.NET Core in the following IIS deployment scenarios:
- Windows Server 2022 / Windows 11 or later
- An
https
url binding is used. - The EnableHttp3 registry key is set.
- When hosting out-of-process: Public-facing edge server connections use HTTP/3, but the reverse proxy connection to the Kestrel server uses HTTP/1.1.
The preceding Windows 11 Build versions may require the use of a Windows Insider build.
For an in-process deployment when an HTTP/3 connection is established, HttpRequest.Protocol
reports HTTP/3
. For an out-of-process deployment when an HTTP/3 connection is established, HttpRequest.Protocol
reports HTTP/1.1
.
For more information on the in-process and out-of-process hosting models, see xref:host-and-deploy/aspnet-core-module.
HTTP/3 is discovered as an upgrade from HTTP/1.1 or HTTP/2 via the alt-svc
header. That means the first request will normally use HTTP/1.1 or HTTP/2 before switching to HTTP/3. IIS doesn't automatically add the alt-svc
header, it must be added by the application. The following code is a middleware example that adds the alt-svc
response header.
app.Use((context, next) =>
{
context.Response.Headers.AltSvc = "h3=\":443\"";
return next(context);
});
Place the preceding code early in the request pipeline.
IIS also supports sending an AltSvc HTTP/2 protocol message rather than a response header to notify the client that HTTP/3 is available. See the EnableAltSvc registry key. Note this requires netsh sslcert bindings that use host names rather than IP addresses.