当前位置: 首页 > news >正文

FRP 后端无法获取请求者IP解决方案

📝 FRP 后端无法获取请求者真实 IP?别慌,解决方案来啦!


🧐 问题背景

当你使用 FRP 进行内网穿透或代理服务时,是否遇到过这样的困扰:
后端服务拿到的客户端 IP 全都是 FRP 服务器的地址,而不是用户的真实 IP?
别担心,这是 FRP 代理场景下的常见问题,但 FRP 早已为我们准备了两种优雅的解决方案!


🛠️ 解决方案一:HTTP X-Forwarded-For

如果你使用的是 HTTP 类型代理,或是启用了 https2httphttps2https 插件,那么恭喜你,这是最简单的方式!

  • 默认启用,无需额外配置
  • ✅ 通过 HTTP Header 中的 X-Forwarded-For 字段获取真实 IP

你的后端服务只需要从 X-Forwarded-For 中读取值,就能轻松拿到用户的真实 IP 地址!


🚀 解决方案二:Proxy Protocol(推荐)

如果你的服务不仅仅是 HTTP,还包含 TCP、HTTPS 甚至 UDP,那么 Proxy Protocol 就是你的救星!

什么是 Proxy Protocol?

简单来说,它是 FRP 与本地服务建立连接时,先发送的一段包含真实客户端 IP 的协议数据。只要你的后端服务支持解析这个协议,就能拿到真实 IP!

如何启用?

1. 在 FRP 客户端配置中开启:

# frpc.toml - HTTPS 示例
[[proxies]]
name = "web"
type = "https"
localPort = 443
customDomains = ["test.yourdomain.com"]# 关键配置:开启 Proxy Protocol
transport.proxyProtocolVersion = "v2"
# frpc.toml - UDP 示例
[[proxies]]
name = "dns"
type = "udp"
localIP = "127.0.0.1"
localPort = 53
remotePort = 6000# 启用 UDP 的 Proxy Protocol
transport.proxyProtocolVersion = "v2"

2. 后端服务配置(以 Nginx 为例):

在 Nginx 的 server 配置中启用 Proxy Protocol 解析:

server {listen 443 ssl proxy_protocol;  # 关键:添加 proxy_protocolserver_name test.yourdomain.com;# 将 Proxy Protocol 中的 IP 设置到 X-Real-IP Headerreal_ip_header proxy_protocol;set_real_ip_from 127.0.0.1;  # 你的 frpc 地址location / {# 现在你的应用可以通过 X-Real-IP 获取真实 IP 了!proxy_set_header X-Real-IP $proxy_protocol_addr;proxy_pass http://localhost:8080;}
}

💡 为什么推荐 Proxy Protocol?

  • 支持所有 TCP/UDP 协议,不限于 HTTP
  • 安全可靠,IP 信息在建立连接时就传递
  • 广泛支持:Nginx、HAProxy 等主流服务都完美兼容
  • UDP 也支持!DNS 等 UDP 服务也能获取真实客户端 IP

🎯 总结对比

方案 适用场景 配置难度 支持协议
X-Forwarded-For HTTP 代理 ⭐⭐ HTTP/HTTPS
Proxy Protocol 所有 TCP/UDP 代理 ⭐⭐⭐ TCP/HTTPS/UDP

💫 最后的小贴士

  1. Proxy Protocol 有两个版本:v1 和 v2,建议使用 v2,更高效更安全
  2. 确保后端服务支持:在配置前确认你的 Nginx、HAProxy 或其他服务开启了 Proxy Protocol 解析能力
  3. 测试验证:配置完成后,记得通过访问测试验证是否能正确获取真实 IP

现在,再也不用为 FRP 后端拿不到真实 IP 而发愁啦!🎉

希望这篇文档能帮你顺利解决问题,如果有任何疑问,欢迎继续探讨!😊
注: 内容由AI润色!

http://www.fuzeviewer.com/news/424/

相关文章:

  • 【CI130x 离在线】如何运行 curl 脚本
  • 这才是真正的AI NAS!极空间私有云Z2Ultra评测
  • 新东方第三节课名言作文
  • 十月阅读_3
  • 中考_体育
  • 常见问题处理 --- phpstudy启动mysql失败
  • 20232308 2025-2026-1 《网络与系统攻防技术》实验三实验报告
  • 【密码学实战】openHiTLS PKCS12命令行程序: PKCS12文件生成与解析
  • 「CTSC2017-游戏」题解
  • vue3 vue3-form-element表单生成工具 输入框增加后缀
  • 20232402 2025-2026-1 《网络与系统攻防技术》实验三实验报告
  • 掘金2025年:数字化商业浪潮下,如何选对平台与伙伴?一站式多商户商城系统推荐榜发布,多商户商城代理招募/多商户项目合伙人加盟/一站式开店代理项目加盟
  • 为医疗器械行业搭建“数字桥梁”,破解协同效率与合规难题
  • PostgreSQL 服务版
  • 20232307 2025-2026-1 《网络与系统攻防技术》实验三实验报告
  • 2025年10月办公家具公司评价榜:基于真实数据的权威推荐清单
  • vue+antv/x6项目使用问题
  • 《程序员修炼之道:从小工到专家》前五分之一观后感
  • 坐标系与投影关系
  • 用gdb的动态视角看ret2text的实现
  • 1027随笔
  • ask_skill
  • SVN 主分支合并之通过主分支合并子分支执行流程
  • 现代c++编程体验2
  • 化繁为简:解密国标GB28181算法算力平台EasyGBS如何以兼容性与易用性赋能安防集成
  • 计算机毕业设计springboot音乐畅听系统 基于Spring Boot框架的智能音乐播放系统编写 Spring Boot驱动的音乐在线欣赏平台构建
  • vue2 封装组件使用 v-mode【el-radio,el-input】
  • P11993 [JOIST 2025] 迁移计划 题解
  • ERP和CRM、SRM、MES之间的关系,怎么理解?
  • 2025年市面上氟碳铝单板品牌、市场氟碳铝单板公司、国内氟碳铝单板生产厂家、2025年氟碳铝单板品牌、口碑好的氟碳铝单板产品综合评测