【实测,使用梯子都能检测😎】在网站使用CF-CDN的情况下获取用户真实IP的方法

Firgt
259 12

有的时候一些用户特别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。

为了您的网站安全,快去行动吧!

一个挺懒的程序猿,还没进化。引导页资源盘小说屋
最新回复 ( 12 )
  • 2
    0
    ?这不是自欺欺人吗
  • Firgt @Ta
    3
    0
    Qpxe2008 ?这不是自欺欺人吗
    怎么个自欺欺人法呢?
    因为有的时候网站获取的都是cdn的IP啊
    用户追查不到服务器的IP,但是服务器可以获取用户的IP
  • Firgt @Ta
    4
    0
    Qpxe2008 ?这不是自欺欺人吗

    而且有的时候一些不怀好意的用户会特别nb,咱们要防范一下网站安全嘛

  • 5
    0
    Firgt 怎么个自欺欺人法呢? 因为有的时候网站获取的都是cdn的IP啊 用户追查不到服务器的IP,但是服务器可以获取用户的IP
    聪明
  • 6
    0
    《用户会特别sm》文明用语
  • 7
    0

    我写了个WordPress插件来处理这个问题:GitHub仓库

    这个插件会自动从Cloudflare API获取和更新CDN的IP列表

    因为我的博客是在虚拟主机上搭建的,不好调整配置文件(

  • Firgt @Ta
    8
    0
    GuGuan123 我写了个WordPress插件来处理这个问题:GitHub仓库 这个插件会自动从Cloudflare API获取和更新CDN的IP列表 因为我的博客是在虚拟主机上搭建的,不好调整配置文件(
    (╭ ̄3 ̄)╭♡
  • Firgt @Ta
    9
    0
    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)出现兼容性问题。

  • 10
    0

    使用梯子能检测我是不太信的啦,后面的没啥问题喵

  • 11
    0
    Firgt GuGuan123 我写了个WordPress插件来处理这个问题:GitHub仓库 这个插件会自动从Cloudflare API获取和更新CDN的IP列表 因为我的博客是在虚拟主机上搭建的,不好 ...

    我相信你是直接把AI回复的问题复制出来,没有真正的看过那个插件代码吧(

    我已经考虑到多层代理的问题了,可以手动设置额外CDN的IP

    IPv6的处理是没有问题的,我在README说对IPv6支持不完善是因为WordPress的找回密码电子邮件并没有提供单独修改IP地址的钩子,所以只能用正则表达式匹配电子邮件里包含的IP地址替换。

    但是评论的IP修正是完全没有问题的,完美支持IPv6

    还有AI提到的“全局 IP 修正模式”根本不会启用…这个功能未来我也不打算实装,因为它会影响网站性能,而且也确实会有冲突问题

  • 12
    0
    你这一句「使用梯子都能检测」把人吓坏了
  • Firgt @Ta
    13
    0
    Gr3yPhMoe 你这一句「使用梯子都能检测」把人吓坏了
    6,我真的是实测得到的
    ๐·°(৹˃̵﹏˂̵৹)°·๐
  • 游客
    14

    您需要登录后才可以回帖

    登录 注册

发新帖