网站首页 > 精选教程 正文
realip 功能介绍
用途:当本机 Nginx 处于反向代理后端时可以获取到用户的真实IP地址。
使用:realip 功能需要 Nginx 添加 ngx_http_realip_module 模块,默认情况下是不被编译,如果需要添加,请在编译时添加 --with-http_realip_module 选项开启它。
realip 作用域
set_real_ip_from、real_ip_header 和 real_ip_recursive 都可以用于 http、 server、location 区域配置。
realip 部分参数解释
- set_real_ip_from:设置反向代理服务器,即信任服务器IP
- real_ip_header X-Forwarded-For:用户真实IP存在X-Forwarded-For请求头中
- real_ip_recursive:
- off:会将real_ip_header指定的HTTP头中的最后一个IP作为真实IP
- on:会将real_ip_header指定的HTTP头中的最后一个不是信任服务器的IP当成真实IP
http 头中的 X-Forwarded-For、X-Real-IP、Remote Address 解释
X-Forwarded-For 位于HTTP请求头,是HTTP的扩展 header,用于表示HTTP请求端真实IP。
格式如下:
X-Forwarded-For: client, proxy1, proxy2
Nginx 代理一般配置为:
proxy_set_header Host $host;proxy_set_header X-Real-IP $remote_addr;proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
解释:
- X-Forwarded-For:Nginx追加上去的,但前面部分来源于nginx收到的请求头,这部分内容不是很可信。符合IP格式的才可以使用,否则容易引发XSS或者SQL注入漏洞。
- Remote Address:HTTP协议没有IP的概念,Remote Address来自于TCP连接,表示与服务端建立TCP连接的设备IP,因此,Remote Address无法伪造。
- X-Real-IP:HTTP代理用于表示与它产生TCP连接的设备IP,可能是其他代理,也可能是真正的请求端。
realip 功能举例说明
下面是一个简单的架构图:
假设一:
1、如果 Nginx 没有使用 realip模块,第二台 Nginx中 X-Forwarded-For 请求是 1.1.1.1,但 remote_addr 地址是 2.2.2.2,这时应用服务可以通过 X-Forwarded-For 字段获取用户真实IP。不过这里有点风险,如果中间多几层反向代理服务,就无法获取唯一一个用户真实IP。
2、如果 Nginx 使用realip模块,并如下设置;Nginx 会取 X-Forwarded-For 最后一个IP也就是 2.2.2.2 作为真实IP。最后应用服务拿到的地址也是 2.2.2.2,但事实这不是用户IP。
set_real_ip_from 2.2.2.2;set_real_ip_from 2.2.2.3;real_ip_header X-Forwarded-For;real_ip_recursive off;
3、如果 Nginx 使用realip模块,并如下设置;由于 2.2.2.2 是信任服务器IP,Nginx 会继续往前查找,发现 1.1.1.1 不是信任服务器IP,就认为是真实IP。但事实 1.1.1.1 也就是用户IP。最后应用服务也拿到唯一的用户真实IP。
set_real_ip_from 2.2.2.2;set_real_ip_from 2.2.2.3;real_ip_header X-Forwarded-For;real_ip_recursive on;
参考链接
- https://cloud.tencent.com/developer/article/1521273
- https://www.cnblogs.com/amyzhu/p/9610056.html
猜你喜欢
- 2025-06-19 35张最新2025年企业所得税汇算清缴年度纳税申报表模板(带公式)
- 2025-06-19 安全生产标准化全套资料模版(947页)
- 2025-06-19 超全完整版手工账电子表单模板汇总,适合中小企业财务会计,收藏
- 2025-06-19 在哪下载大学ppt模板?这四款软件一定要来看看
- 2025-06-19 10个顶级的office学习网站,5天让你菜鸟变大神,月薪过万不用愁
- 2025-06-19 你一直在找的矢量小人的素材,这个网站一大把!赶紧偷偷私藏起来
- 2025-06-19 你的妇女节PPT有了!分享三个免费的PPT下载方式
- 2025-06-19 提高PPT效率的5个专用网站,阿里这款三维图标素材,免费下载!
- 2025-06-19 PPT想要高大上?6大免费高清图片下载网站帮你大忙!
- 2025-06-19 各种ppt模板可以在哪免费下载?这些方法快来试试
你 发表评论:
欢迎- 最近发表
- 标签列表
-
- nginx反向代理 (57)
- nginx日志 (56)
- nginx限制ip访问 (62)
- mac安装nginx (55)
- java和mysql (59)
- java中final (62)
- win10安装java (72)
- java启动参数 (64)
- java链表反转 (64)
- 字符串反转java (72)
- java逻辑运算符 (59)
- java 请求url (65)
- java信号量 (57)
- java定义枚举 (59)
- java字符串压缩 (56)
- java中的反射 (59)
- java 三维数组 (55)
- java插入排序 (68)
- java线程的状态 (62)
- java异步调用 (55)
- java中的异常处理 (62)
- java锁机制 (54)
- java静态内部类 (55)
- java怎么添加图片 (60)
- java 权限框架 (55)
本文暂时没有评论,来添加一个吧(●'◡'●)