ASP.NET Core 后端如何通过 Nginx 获取真实客户端 IP 完整指南

ASP.NET Core 应用部署在 Nginx 反向代理后面时,应用默认获取的是 Nginx 服务器的 IP 地址,而不是真实的客户端 IP。这是因为所有请求都经过 Nginx 转发,导致源 IP 信息丢失。对于需要 记录客户端日志、访问控制或安全策略 的应用来说,这会造成严重影响。

解决方案概览

要解决这个问题,需要在两个层面进行配置:

  1. Nginx 配置:转发客户端 IP 信息到后端

  2. ASP.NET Core 配置:正确读取转发的 IP 信息

一、Nginx 配置

这里我就先部署在80端口

javascript 复制代码
server {
    listen 80;
    server_name yourdomain.com;

    location / {
        # 转发真实 IP 的头部信息
        proxy_set_header X-Real-IP $remote_addr;
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        proxy_set_header X-Forwarded-Proto $scheme;
        proxy_set_header X-Forwarded-Host $host;
        proxy_set_header X-Forwarded-Port $server_port;
    }
}

二、ASP.NET Core 配置

Program.cs(.NET 6+)中:

cs 复制代码
var builder = WebApplication.CreateBuilder(args);

// 生产环境开启真实 IP 获取
if (!builder.Environment.IsDevelopment())
{
    builder.Services.Configure<ForwardedHeadersOptions>(options =>
    {
        options.ForwardedHeaders = ForwardedHeaders.XForwardedFor | ForwardedHeaders.XForwardedProto;

        // 信任 Nginx 代理 IP
        options.KnownProxies.Clear();
        //只信任这一个IP
        options.KnownProxies.Add(IPAddress.Parse("192.168.20.90"));
        // 如果有多级代理,可调大 ForwardLimit
        options.ForwardLimit = 1;
    });
}

var app = builder.Build();

// 启用中间件
if (!app.Environment.IsDevelopment())
{
    // 必须在认证、路由、CORS 之前
    app.UseForwardedHeaders();
}

app.UseRouting();

app.UseEndpoints(endpoints =>
{
    endpoints.MapGet("/", async context =>
    {
        var ip = context.Connection.RemoteIpAddress;
        var scheme = context.Request.Scheme;

        await context.Response.WriteAsync($"客户端 IP: {ip}, 请求协议: {scheme}");
    });
});

app.Run();

通过 Nginx 转发和 ASP.NET Core 的 ForwardedHeaders 中间件,可以安全、准确地获取客户端真实 IP,即使在 HTTPS 终端代理或多级代理场景下也能正确工作。

相关推荐
墨风如雪4 小时前
甲骨文云(Oracle Cloud)最新注册防坑记录:被ABC了怎么办?
服务器
道清茗5 小时前
【RH294知识点汇总】第 9 章 《 自动执行 Linux 管理任务 》常见问题
linux·运维·服务器
数据法师6 小时前
开源情报收集工具GhostTrack深度测评:IP、手机号、用户名的合规信息查询方案
网络·网络协议·tcp/ip
丑八怪大丑7 小时前
Java网络编程
linux·服务器·网络
想成为优秀工程师的爸爸8 小时前
第三十篇技术笔记:郭大侠学UDS - 人有生老三千疾,望闻问切良方医
网络·笔记·网络协议·tcp/ip·信息与通信
橙子也要努力变强8 小时前
信号捕捉底层机制-机理篇2
linux·服务器·c++
Jinkxs9 小时前
LoadBalancer- 主流负载均衡工具盘点:Nginx / Haproxy / Keepalived 基础介绍
运维·nginx·负载均衡
CQU_JIAKE9 小时前
4.28~4.30【Q】
linux·运维·服务器
先知后行。9 小时前
Linux 设备模型和platform平台
linux·运维·服务器
Data_Journal10 小时前
如何使用cURL更改User Agent
大数据·服务器·前端·javascript·数据库