0
alper created
Support Team
My website is behind a proxy server / load balancer and the client ip is passed in a custom HTTP header.
To get the Identity Server work, we need to use the custom HTTP header.
The client IP is stored in X-Original-Host
HTTP header.
1 Answer(s)
-
0
Create the below extension class in your web project. Set the
ForwardedHeaderName
to whatever HTTP header the real IP address is in.public static class ApplicationBuilderExtensions { public static IApplicationBuilder UseCustomHttpHeaders(this IApplicationBuilder builder) { var options = new ForwardedHeadersOptions { ForwardedForHeaderName = ForwardedHeadersDefaults.XOriginalHostHeaderName, //"X-Original-Host" ForwardedHeaders = ForwardedHeaders.XForwardedFor | ForwardedHeaders.XForwardedProto }; options.KnownNetworks.Clear(); options.KnownProxies.Clear(); return builder.UseForwardedHeaders(options); } }
Open your web module class.
public override void OnApplicationInitialization(ApplicationInitializationContext context) { var app = context.GetApplicationBuilder(); var env = context.GetEnvironment(); if (env.IsDevelopment()) { app.UseDeveloperExceptionPage(); app.UseCustomHttpHeaders(); } else { app.UseErrorPage(); app.UseCustomHttpHeaders(); app.UseHsts(); app.UseAllElasticApm(context.GetConfiguration()); } //...
Create a simple controller to test it.
public class Test : Controller { public string Index() { return "Client IP Address: " + HttpContext.Connection.RemoteIpAddress.ToString(); } }
Open Postman and make a GET request to TestController
PS: If you want to use
X-Forwarded-For
header, then removeForwardedForHeaderName = "X-Original-Host"
.References:
- https://docs.microsoft.com/en-us/aspnet/core/host-and-deploy/proxy-load-balancer
- https://github.com/IdentityServer/IdentityServer4/blob/main/src/IdentityServer4/src/Endpoints/DiscoveryEndpoint.cs#L53
- https://github.com/IdentityServer/IdentityServer4/blob/main/src/IdentityServer4/src/Extensions/HttpContextExtensions.cs#L108
- https://github.com/IdentityServer/IdentityServer4/blob/main/src/IdentityServer4/src/Extensions/HttpContextExtensions.cs#L88