一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|JavaScript|易語言|

服務器之家 - 編程語言 - Java教程 - java 偽造http請求ip地址的方法

java 偽造http請求ip地址的方法

2021-06-02 12:18碼魘 Java教程

這篇文章主要介紹了java 偽造http請求ip地址的方法,小編覺得挺不錯的,現在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧

最近做接口開發,需要跟第三方系統對接接口,基于第三方系統接口的保密性,需要將調用方的請求ip加入到他們的白名單中。由于我們公司平常使用的公網的ip是不固定的,每次都需要將代碼提交到固定的服務器上(服務器ip加入了第三方系統的白名單),頻繁的修改提交合并代碼和啟動服務器造成了額外的工作量,給接口聯調帶來了很大的阻礙。

正常的http請求

我們正常發起一個http的請求如下:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
import org.apache.http.httpentity;
import org.apache.http.client.config.requestconfig;
import org.apache.http.client.methods.closeablehttpresponse;
import org.apache.http.client.methods.httppost;
import org.apache.http.entity.stringentity;
import org.apache.http.impl.client.closeablehttpclient;
import org.apache.http.impl.client.httpclients;
import org.apache.http.util.entityutils;
 
public static string getpost4json(string url, string json) throws exception {
  closeablehttpclient httpclient = httpclients.createdefault();
  httppost httppost = new httppost(url);
  /* 設置超時 */
  requestconfig defaultrequestconfig = requestconfig.custom().setsockettimeout(5000).setconnecttimeout(5000).setconnectionrequesttimeout(5000).build();
  httppost.setconfig(defaultrequestconfig);
  httppost.addheader("content-type", "application/json;charset=utf-8");
  httppost.setentity(new stringentity(json, "utf-8"));
  closeablehttpresponse response = null;
  string result = null;
  try {
    response = httpclient.execute(httppost);
    httpentity entity = response.getentity();
    result = entityutils.tostring(entity, "utf-8");
  } catch (exception e) {
    throw e;
  } finally {
    if (response != null) response.close();
    httpclient.close();
  }
  return result;
}

由于沒有加入白名單的原因,這樣的請求顯然無法調用到第三方的接口。這時候考慮能否將請求的ip改為白名單的一個ip,服務器在解析時拿到的不是正常的ip,這樣能否正常調用呢?

偽造http請求ip地址

我們知道正常的tcp/ip在通信過程中是無法改變源ip的,也就是說電腦獲取到的請求ip是不能改變的。但是可以通過偽造數據包的來源ip,即在http請求頭加一個x-forwarded-for的頭信息,這個頭信息配置的是ip地址,它代表客戶端,也就是http的請求端真實的ip。因此在上面代碼中加上如下代碼:

?
1
httppost.addheader("x-forwarded-for",ip);

服務端通過x-forwarded-for獲取請求ip,并且校驗ip安全性,代碼如下:

?
1
string ip = request.getheader("x-forwarded-for");

總結

通過請求頭追加x-forwarded-for頭信息可以偽造http請求ip地址。但是若服務器不直接信任并且不使用傳遞過來的 x-forward-for 值的時候偽造ip就不生效了。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持服務器之家。

原文鏈接:https://segmentfault.com/a/1190000016537618

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 成年无限观看onlyfans | 午夜私人影院在线观看 视频 | 毛片免| 26uuu久久| 91污无限制破解安卓2021 | 小SAO货边洗澡边CAO你动漫 | 西施打开双腿下面好紧 | 青草久久影院 | 国产特黄一级一片免费 | 校园全黄h全肉细节文 | 人人最怕九月羊 | 亚洲九九爱 | 亚洲视屏在线观看 | 日本中文字幕不卡在线一区二区 | 国产精品手机视频一区二区 | 成人永久免费福利视频网站 | 日本护士xxxx视频 | 99久久这里只有精品 | 韩国美女激情vip | 国产伦码精品一区二区三区 | 91久久国产成人免费观看资源 | 福利入口在线观看 | 好大好深受不了了快进来 | 王的视频vk | 嫩交18xxxx | 天天操天天射天天色 | 欧美日韩在线一区二区三区 | www射com | 2022超帅男同gayxxx | 亚洲a图| 香蕉久草在线 | 色花堂国产精品首页第一页 | 波多野结衣同性系列698 | 亚洲高清成人 | 午夜私人福利影院 | 欧美国产合集在线视频 | 久久精品在现线观看免费15 | 含羞草传媒一天免费看下 | 日本激情小说 | 亚洲色大成网站www久久九九 | china国产bbw |