.NET6 解决 Nginx 反向代理后获取客户端真实 IP(始终显示网关 IP)问题

假设现在你的服务器结构是这样:

  • 客户端真实公网 IP:36.112.25.88

  • Nginx 网关 IP:192.20.1.1

  • .NET 6 服务部署在本机 5000 端口

你在代码里这样获取 IP:

cs 复制代码
var ip = HttpContext.Connection.RemoteIpAddress?.ToString();

结果打印出来的永远是

192.20.1.1

而不是

36.112.25.88

一、为什么会出现这种现象?

因为在反向代理结构下:

  • .NET 接收到的请求是来自 Nginx

  • 网络层认为"请求发起者"就是 Nginx

  • 因此 RemoteIpAddress 返回的是网关 IP

换句话说:

反向代理改变了请求的直接来源。

这是一种正常行为,而不是程序错误。


二、真实 IP 在哪里?

Nginx 在转发请求时,会自动把客户端真实 IP 写入请求头:

cs 复制代码
X-Forwarded-For: 36.112.25.88
X-Real-IP: 36.112.25.88

但默认情况下:

ASP.NET Core 不会自动解析这些头。

原因是 HTTP 头可以伪造,框架出于安全考虑默认关闭信任机制。


三、正确解决方案

解决思路:

  1. Nginx 传递真实 IP

  2. .NET 6 显式启用 ForwardedHeaders


第一步:Nginx 反向代理配置

复制代码
cs 复制代码
server {
    listen 80;
    server_name api.test.com;

    location / {
        proxy_pass http://127.0.0.1:5000;

        proxy_set_header Host $host;
        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;
    }
}

关键配置:

cs 复制代码
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;

第二步:.NET 6 启用 ForwardedHeaders

Program.cs 中配置:

cs 复制代码
using Microsoft.AspNetCore.HttpOverrides;
using System.Net;

var builder = WebApplication.CreateBuilder(args);

builder.Services.Configure<ForwardedHeadersOptions>(options =>
{
    options.ForwardedHeaders =
        ForwardedHeaders.XForwardedFor |
        ForwardedHeaders.XForwardedProto;

    // 指定你的 Nginx 网关 IP
    options.KnownProxies.Add(IPAddress.Parse("192.20.1.1"));
});

var app = builder.Build();

// 必须放在最前面
app.UseForwardedHeaders();

app.MapControllers();

app.Run();

四、配置完成后的结果

请求仍然经过:

cs 复制代码
36.112.25.88 → 192.20.1.1 → .NET

但现在:

  • .NET 会信任来自 192.20.1.1 的转发信息

  • 自动解析 X-Forwarded-For

此时:

cs 复制代码
RemoteIpAddress

获取到的就是:

cs 复制代码
36.112.25.88

五、核心总结

在 Nginx 反向代理结构下:

  • 未配置时 → 获取到的是网关 IP

  • 正确配置后 → 获取到的是真实客户端 IP

本质原因是:

请求的直接来源变成了 Nginx,需要显式启用转发头解析机制。

相关推荐
袁小皮皮不皮3 小时前
1.HCIP BFD 学习笔记(优化版)
服务器·网络·笔记·网络协议·学习·智能路由器·ip
vsropy4 小时前
Ubuntu网络图标消失问题/有网络问号
linux·运维·ubuntu
fofantasy4 小时前
NSK LH12AN 微型导轨技术手册
运维·网络·数据库·经验分享·规格说明书
coderwu4 小时前
Ubuntu 24.04 终端输入 openclaw config 提示未找到命令解决办法
linux·运维·ubuntu
dxxt_yy4 小时前
千兆光/电口+OTDR一体——成都鼎讯 SZT-1000A 千兆以太网测试仪助力风电能源光缆管理
运维·服务器·能源
tedcloud1235 小时前
taste-skill部署教程:打造个性化AI推荐工作流
服务器·前端·人工智能·系统架构·edge
凡人叶枫6 小时前
Effective C++ 条款28:避免使用 handles 指向对象内部
linux·服务器·开发语言·c++·嵌入式开发
AI帮小忙6 小时前
Debian系linux操作系统里安装OpenClaw
linux·运维·debian
极创信息6 小时前
Linux挖矿病毒深度清理实战教程,从进程隐藏、Rootkit驻留到彻底根除
java·大数据·linux·运维·安全·tomcat·健康医疗
志栋智能7 小时前
超自动化巡检剧本(Playbook):运维经验的数字化封装
运维·自动化