[發明專利]一種基于Kong網關獲取客戶端IP的方法在審
| 申請號: | 202010085252.4 | 申請日: | 2020-02-10 |
| 公開(公告)號: | CN111343293A | 公開(公告)日: | 2020-06-26 |
| 發明(設計)人: | 張鵬 | 申請(專利權)人: | 北京首汽智行科技有限公司 |
| 主分類號: | H04L29/12 | 分類號: | H04L29/12;H04L29/06;H04L29/08 |
| 代理公司: | 北京世譽鑫誠專利代理事務所(普通合伙) 11368 | 代理人: | 李世端 |
| 地址: | 100026 北京*** | 國省代碼: | 北京;11 |
| 權利要求書: | 查看更多 | 說明書: | 查看更多 |
| 摘要: | |||
| 搜索關鍵詞: | 一種 基于 kong 網關 獲取 客戶端 ip 方法 | ||
本發明公開的基于Kong網關獲取客戶端IP的方法,涉及網絡技術領域,通過為IP數組proxy_add_x_forwarded_for設置環境參數is_first并根據該環境參數is_first解析IP數組proxy_add_x_forwarded_for,適用于Kong網關未被代理及被代理的場景,提高了兼容性。
技術領域
本發明屬于網絡技術領域,具體涉及一種基于Kong網關獲取客戶端IP的方法。
背景技術
隨著移動互聯網技術的深入應用,基于前后臺分離的應用場景越來越多。通過API-gateway管控后臺接口的方式變得尤為重要,Kong網關作為API-gateway,就是其中最突出的一款產品形態。通過API-gateway可以實現對后臺節點的如下管控:IP限流、IP黑白名和服務降級等。
Kong網關作為一種API-gateway開源技術,已實現了對HTTP請求的限流和和黑白名單控制。
在使用Kong網關的過程中,當Kong網關被反向代理服務器代理后,HTTP請求經過一層或者多層反向代理(如Openresty),請求到Kong網關上,Kong網關再路由請求到后臺節點,此時獲取不到用戶端的真實IP,導致基于IP的攔截策略失效,如IP限流、IP黑白名單等等都會失效。
現有方案僅從一個維度進行處理,即只是從HTTP請求中提取固定IP remote_addr的值,不適Kong網關被代理的場景,兼容性較差。
發明內容
針對現有技術存在的缺陷,本發明實施例提供了一種基于Kong網關獲取客戶端IP的方法,該方法包括以下步驟:
接收客戶端發送的HTTP請求并從所述HTTP請求的請求頭中獲取IP數組proxy_add_x_forwarded_for;
判斷IP數組proxy_add_x_forwarded_for是否為空,若是,則從所述HTTP請求中提取遠程IP remote_addr,將所述遠程IP remote_addr中的IP作為客戶端IP;
如否,則解析IP數組proxy_add_x_forwarded_for,從所述IP數組proxy_add_x_forwarded_for中獲取客戶端IP。
優選地,從所述IP數組proxy_add_x_forwarded_for中獲取客戶端IP包括:
獲取所述IP數組proxy_add_x_forwarded_for中預設的環境參數is_first,當環境參數is_first為真時,將所述IP數組proxy_add_x_forwarded_for中的第一個IP作為客戶端IP。
優選地,從所述IP數組proxy_add_x_forwarded_for中獲取客戶端IP還包括:
當環境參數is_first為假時,將所述IP數組proxy_add_x_forwarded_for中的最后一個IP作為客戶端IP。
優選地,在獲取到客戶端IP之后,所述方法還包括:
根據所述客戶端IP的攔截策略,處理所述HTTP請求。
本發明實施例提供的基于Kong網關獲取客戶端IP的方法具有以下有益效果:
通過為IP數組proxy_add_x_forwarded_for設置環境參數is_first并根據該環境參數is_first解析IP數組proxy_add_x_forwarded_for,適用于Kong網關未被代理及被代理的場景,提高了兼容性。
具體實施方式
以下結合具體實施例對本發明作具體的介紹。
該專利技術資料僅供研究查看技術是否侵權等信息,商用須獲得專利權人授權。該專利全部權利屬于北京首汽智行科技有限公司,未經北京首汽智行科技有限公司許可,擅自商用是侵權行為。如果您想購買此專利、獲得商業授權和技術合作,請聯系【客服】
本文鏈接:http://www.szxzyx.cn/pat/books/202010085252.4/2.html,轉載請聲明來源鉆瓜專利網。
- 上一篇:區塊存儲方法、裝置、節點設備及存儲介質
- 下一篇:一種圖像處理方法及裝置





