後端獲取不到客戶端真實IP,獲取的是WAF 的IP

後端獲取不到真實IP,獲取的是WAF 的IP

一、問題詳情

image-20200514091007244

最近在線上遇到這樣的問題,部分服務需要記錄客戶端的真實IP,但是實際記錄的是 WAF的IP ,我們在 Nginx 前面接入了 WAF 。但是我們在 Nginx 層面也是設置了將真實IP 傳入到後端的。所以我們懷疑是後端拿錯值了。

  • Nginx 配置

    proxy_set_header X-Real-IP $remote_addr;
    proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
    

進行排查代碼,發現默認代碼裏面拿取的是 X-Real-IP ,但是這個IPNginx 層面我們已經設置爲了 waf 的IP。

image-20200512142118934

2、 問題解決

  1. 更改上面的 代碼

    開發需要去做的。不拿 X-Real-IP 去拿 X-Forwarded-For 的字段的第一個值。
    
  2. 更改Nginx 的配置。

    1. 方法一

      • proxy_set_header X-Real-IP $proxy_add_x_forwarded_for;
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        
    2. 方法二

      • 去除這個值:proxy_set_header X-Real-IP $remote_addr;  讓後端獲取不到 X-Real-IP的值
        
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章