Nginx 防止IP伪造,绕过IP限制

背景介绍

在使用Nginx时,需要将IP地址转发到后置应用中,往往需要增加配置

proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;

在后端程序通过读取请求头里的X-Forwarded-For来获取用户客户端IP。

java 复制代码
public String getRemortIP(HttpServletRequest request) { 
  if (request.getHeader("x-forwarded-for") == null) { 
    return request.getRemoteAddr(); 
  } 
  return request.getHeader("x-forwarded-for"); 
}

但是,这个X-Forwarded-For可以通过修改报文来伪造IP。

解决办法

Nginx中增加配置

proxy_set_header X-Real-IP $remote_addr; #让WEB取得原始请求IP

代码中取客户端IP

java 复制代码
String clientIp = request.getHeader("X-Real-IP");
相关推荐
unirst19850071 分钟前
使用vite打包并部署vue项目到nginx
前端·vue.js·nginx
Albert Edison3 分钟前
【Python】文件
android·服务器·python
未来之窗软件服务5 分钟前
服务器运维(三十三)日志分析ssh日志工具—东方仙盟
运维·服务器·ssh·仙盟创梦ide·东方仙盟
梦雨羊11 分钟前
搭建服务器进行测试
linux·运维·服务器
哼?~39 分钟前
磁盘与文件系统
linux
Bigbig.42 分钟前
Linux 挖矿病毒深度排查与修复实录
linux·安全
GeminiJM1 小时前
LangGraph 源码学习笔记
linux·笔记·学习·langchain
charlie1145141911 小时前
RK3568跑Ubuntu 24.04全路程指南(以正点原子的RK3568开发板为例子)
linux·笔记·ubuntu·rootfs·教程·环境配置·rk3568
MyFreeIT1 小时前
OpenSSL
linux·运维·服务器
瀚高PG实验室1 小时前
hghac8008漏洞扫描处理
linux·网络·windows·瀚高数据库