有的时候一些用户特别nb,会攻击你的网站或者说是在你的网站下面乱发评论,但是查IP又查不到
我的网盘自从用上cdn后,我就发现上传用户的IP不正常,一查,都是cdn的IP😂
我相信你也被这几个问题困扰过,现在看看解决方法
困扰了好长时间
后来查了一下官方文档,发现修改Nginx配置文件最为容易
只要添加以下代码即可(宝塔里面直接修改网站配置)
# 配置真实IP获取(添加了指定的所有IP网段)后面的IP是你的cdn的IP
set_real_ip_from 173.245.48.0/20;
set_real_ip_from 103.21.244.0/22;
set_real_ip_from 103.22.200.0/22;
set_real_ip_from 103.31.4.0/22;
set_real_ip_from 141.101.64.0/18;
set_real_ip_from 108.162.192.0/18;
set_real_ip_from 190.93.240.0/20;
set_real_ip_from 188.114.96.0/20;
set_real_ip_from 197.234.240.0/22;
set_real_ip_from 198.41.128.0/17;
set_real_ip_from 162.158.0.0/15;
set_real_ip_from 104.16.0.0/13;
set_real_ip_from 104.24.0.0/14;
set_real_ip_from 172.64.0.0/13;
set_real_ip_from 131.0.72.0/22;
set_real_ip_from 2400:cb00::/32;
set_real_ip_from 2606:4700::/32;
set_real_ip_from 2803:f800::/32;
set_real_ip_from 2405:b500::/32;
set_real_ip_from 2405:8100::/32;
set_real_ip_from 2a06:98c0::/29;
set_real_ip_from 2c0f:f248::/32;
set_real_ip_from 127.0.0.1; # 本地代理(如Nginx反向代理)
set_real_ip_from ::1; # IPv6本地代理
# 如果是非cf-cdn,从X-Forwarded-For头中获取真实IP
real_ip_header CF-Connecting-IP;
事前确保nginx是否启用了http_realip模块。我这里是在Ubuntu 22.04中使用apt安装的nginx,已经包含了该模块。可以使用如下指令检查nginx -V输出的信息是否包含--with-http_realip_module。
nginx -V 2>&1 | grep "realip"
其中Cloudflare IP可参考https://www.cloudflare.com/ips/ 。经过查看访问日志,我的网站使用Cloudflare CDN后,所有请求来源IP均在这两个地址块范围,后面配置防火墙时也只放通了这两块地址,所以只填了这两个地址块。
最后使用nginx -t验证配置文件,nginx -s reload重新加载配置即可。
可以看到啊,也是成功的把我家IPv6搞出来了。
后面经过几次测试,发现我使用梯子均可以查到原连接IP。
为了您的网站安全,快去行动吧!
GuGuan123 我写了个WordPress插件来处理这个问题:GitHub仓库 这个插件会自动从Cloudflare API获取和更新CDN的IP列表 因为我的博客是在虚拟主机上搭建的,不好调整配置文件(
补对,我来说说一些问题
多CDN、IPv6优先/仅IPv6、多层代理的网站怎么办?
Forwarded HTTP 头部的处理逻辑标注为 “未完善”(getForwardedIp方法),如果依赖该头部提取 IP,可能出现解析错误。
全局 IP 修正模式(mode: global)直接替换$_SERVER['REMOTE_ADDR'],可能与其他依赖该变量的插件(如安全审计、访问统计工具)产生冲突,且未提供冲突规避机制。
代码中 PHP 版本标注存在不一致(插件主文件同时标注PHP Version: 8.2和Requires PHP: 7.0),可能导致低版本 PHP 环境(如 7.0-7.3)出现兼容性问题。
Firgt GuGuan123 我写了个WordPress插件来处理这个问题:GitHub仓库 这个插件会自动从Cloudflare API获取和更新CDN的IP列表 因为我的博客是在虚拟主机上搭建的,不好 ...
我相信你是直接把AI回复的问题复制出来,没有真正的看过那个插件代码吧(
我已经考虑到多层代理的问题了,可以手动设置额外CDN的IP
IPv6的处理是没有问题的,我在README说对IPv6支持不完善是因为WordPress的找回密码电子邮件并没有提供单独修改IP地址的钩子,所以只能用正则表达式匹配电子邮件里包含的IP地址替换。
但是评论的IP修正是完全没有问题的,完美支持IPv6
还有AI提到的“全局 IP 修正模式”根本不会启用…这个功能未来我也不打算实装,因为它会影响网站性能,而且也确实会有冲突问题