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");
相关推荐
三万棵雪松23 分钟前
【Linux 物联网网关主控系统-Web部分(一)】
linux·前端·嵌入式linux
qZ6bgMe4326 分钟前
记录一次bug:不可见字符/零宽字符
服务器·.net
2301_771717211 小时前
Jackson的使用方法详解
java·服务器·前端
似水এ᭄往昔1 小时前
【Linxu】--进程优先级和进程切换
linux·运维·服务器
海参崴-1 小时前
Linux进程管理完全指南
linux·运维·服务器
CQU_JIAKE1 小时前
4.4【A】
运维·服务器
kyle~1 小时前
Linux系统优化---PREEMPT_RT机器人开发方向
linux·运维·机器人
独隅2 小时前
在 Linux 上部署 TensorFlow 模型的全面指南
linux·运维·tensorflow
Strange_Head2 小时前
《Linux系统编程篇》Linux Socket 网络编程02 (Linux 进程间通信(IPC))——基础篇
linux·运维·网络
星河耀银海2 小时前
JAVA IO流:从基础原理到实战应用
java·服务器·开发语言