0

0

php在nginx下获取本机ip不同_php配nginx取ip区别【步骤】

星夢妙者

星夢妙者

发布时间:2026-02-05 13:27:10

|

349人浏览过

|

来源于php中文网

原创

$_SERVER['REMOTE_ADDR'] 在 Nginx + PHP-FPM 下不等于真实客户端 IP,是因为 Nginx 默认以代理身份转发请求,使 REMOTE_ADDR 显示自身地址(如 127.0.0.1),而真实 IP 需通过 real_ip 模块配合 proxy_set_header 和 set_real_ip_from 等配置从可信 HTTP 头(如 X-Real-IP)提取并验证。

php在nginx下获取本机ip不同_php配nginx取ip区别【步骤】

为什么 $_SERVER['REMOTE_ADDR'] 在 Nginx + PHP-FPM 下不等于真实客户端 IP

因为 Nginx 默认不会把原始请求的 IP 透传给后端 PHP-FPM,而是把自身作为代理,把连接来源(比如本机 127.0.0.1)当作 REMOTE_ADDR。真实 IP 被压在 HTTP 头里(如 X-Forwarded-ForX-Real-IP),PHP 默认不读这些头。

常见现象:$_SERVER['REMOTE_ADDR'] 永远是 127.0.0.1::1$_SERVER['HTTP_X_FORWARDED_FOR'] 可能为空或为逗号分隔字符串(含代理链);$_SERVER['HTTP_X_REAL_IP'] 可能未设置。

  • Nginx 必须显式用 proxy_set_header 把真实 IP 注入请求头
  • PHP 不会自动解析或覆盖 REMOTE_ADDR,需自行从可信头提取并校验
  • 不能无条件信任 X-Forwarded-For —— 它可被客户端伪造,只应在 Nginx 确认可信代理后才使用

Nginx 配置:必须设置 proxy_set_header X-Real-IPreal_ip 指令

光加 proxy_set_header 不够,Nginx 还得用 real_ip 模块识别并替换 $remote_addr,否则 PHP-FPM 收到的仍是 Nginx 的连接地址。

确保 Nginx 编译时启用了 --with-http_realip_module(主流发行版包通常已启用)。

立即学习PHP免费学习笔记(深入)”;

拍我AI
拍我AI

AI视频生成平台PixVerse的国内版本

下载
  • location ~ \.php$ 块内添加:
    proxy_set_header X-Real-IP $remote_addr;
    proxy_set_header X-Forwarded-For $remote_addr;
  • httpserver 块中添加:
    set_real_ip_from 127.0.0.1;(若 PHP-FPM 与 Nginx 同机)
    real_ip_header X-Real-IP;(指定用哪个头还原 $remote_addr
  • 如果前端还有 Cloudflare、CDN 或负载均衡器,要把它们的出口 IP 加入 set_real_ip_from,并改用 X-Forwarded-ForX-Forwarded-For 最右非私有 IP(需配合 real_ip_recursive on;

PHP 中安全获取客户端 IP 的推荐写法

不要直接用 $_SERVER['HTTP_X_FORWARDED_FOR']$_SERVER['HTTP_X_REAL_IP'],必须结合 Nginx 的可信代理配置做白名单判断。

假设你已在 Nginx 中设定了 set_real_ip_from 127.0.0.1; 且启用了 real_ip_header X-Real-IP;,那么 PHP 中最简且安全的方式是:

// 优先取经 real_ip 模块处理后的 REMOTE_ADDR(即真实客户端 IP)
$client_ip = $_SERVER['REMOTE_ADDR'] ?? '0.0.0.0';

// 若需兼容未启用 real_ip 的旧配置,再 fallback 到可信头
if (isset($_SERVER['HTTP_X_REAL_IP']) && filter_var($_SERVER['HTTP_X_REAL_IP'], FILTER_VALIDATE_IP)) {
    $client_ip = $_SERVER['HTTP_X_REAL_IP'];
}
  • 避免解析 X-Forwarded-For 字符串 —— 它可能被伪造,且格式不统一(如 "203.0.113.195, 198.51.100.1"
  • 永远用 filter_var(..., FILTER_VALIDATE_IP) 校验,防止注入或非法值
  • 若 Nginx 未启用 real_ip 模块,$_SERVER['REMOTE_ADDR'] 就不可信,此时只能依赖 X-Real-IP,但前提是 Nginx 确实设置了它且来源可控

验证是否生效:检查 Nginx 日志和 PHP 输出

光改配置不测试,等于没改。两个关键验证点:

  • 在 Nginx access_log 中加入 $remote_addr$http_x_real_ip,看访问日志里是否出现真实公网 IP
  • 写个临时 PHP 文件输出:
    var_dump($_SERVER['REMOTE_ADDR'], $_SERVER['HTTP_X_REAL_IP'], $_SERVER['HTTP_X_FORWARDED_FOR']);
  • curl -H "X-Real-IP: 1.2.3.4" http://yoursite/test.php 测试伪造头是否被忽略(应仍显示真实 IP,说明 real_ip 生效)
  • 若用 Docker 或反向代理链,注意容器网络地址(如 172.x.x.x)也需加入 set_real_ip_from

最容易被忽略的是 real_ip 模块未启用或 set_real_ip_from 漏掉某一级代理 IP —— 这会导致 REMOTE_ADDR 始终不变,而你以为 PHP 代码有问题。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
nginx 重启
nginx 重启

nginx重启对于网站的运维来说是非常重要的,根据不同的需求,可以选择简单重启、平滑重启或定时重启等方式。本专题为大家提供nginx重启的相关的文章、下载、课程内容,供大家免费下载体验。

233

2023.07.27

nginx 配置详解
nginx 配置详解

Nginx的配置是指设置和调整Nginx服务器的行为和功能的过程。通过配置文件,可以定义虚拟主机、HTTP请求处理、反向代理、缓存和负载均衡等功能。Nginx的配置语法简洁而强大,允许管理员根据自己的需要进行灵活的调整。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

508

2023.08.04

nginx配置详解
nginx配置详解

NGINX与其他服务类似,因为它具有以特定格式编写的基于文本的配置文件。本专题为大家提供nginx配置相关的文章,大家可以免费学习。

521

2023.08.04

tomcat和nginx有哪些区别
tomcat和nginx有哪些区别

tomcat和nginx的区别:1、应用领域;2、性能;3、功能;4、配置;5、安全性;6、扩展性;7、部署复杂性;8、社区支持;9、成本;10、日志管理。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

235

2024.02.23

nginx报404怎么解决
nginx报404怎么解决

当访问 nginx 网页服务器时遇到 404 错误,表明服务器无法找到请求资源,可以通过以下步骤解决:1. 检查文件是否存在且路径正确;2. 检查文件权限并更改为 644 或 755;3. 检查 nginx 配置,确保根目录设置正确、没有冲突配置等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

406

2024.07.09

Nginx报404错误解决方法
Nginx报404错误解决方法

解决方法:只需要加上这段配置:try_files $uri $uri/ /index.html;即可。想了解更多Nginx的相关内容,可以阅读本专题下面的文章。

3584

2024.08.07

nginx部署php项目教程汇总
nginx部署php项目教程汇总

本专题整合了nginx部署php项目教程汇总,阅读专题下面的文章了解更多详细内容。

41

2026.01.13

nginx配置文件详细教程
nginx配置文件详细教程

本专题整合了nginx配置文件相关教程详细汇总,阅读专题下面的文章了解更多详细内容。

58

2026.01.13

java中fail含义
java中fail含义

本专题整合了java中fail的含义、作用相关内容,阅读专题下面的文章了解更多详细内容。

0

2026.02.05

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PHP课程
PHP课程

共137课时 | 11.1万人学习

JavaScript ES5基础线上课程教学
JavaScript ES5基础线上课程教学

共6课时 | 11.2万人学习

PHP新手语法线上课程教学
PHP新手语法线上课程教学

共13课时 | 0.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号