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

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

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

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 无码人妻视频又大又粗欧美 | 精品综合一区二区三区 | 国产精品久久久久久搜索 | 亚洲高清中文字幕精品不卡 | 色播艾小青国产专区在线播放 | 东京道一本热大交乱 | 亚洲天堂网在线观看视频 | 国产麻豆传媒在线观看 | 高中生放荡日记高h娜娜 | 欧美精品一国产成人性影视 | 好大好想要 | 国产日韩欧美综合一区二区三区 | 国产日本欧美亚洲精品视 | 亚洲国产日韩欧美mv | 亚洲精品私拍国产福利在线 | 好紧水好多| 亚洲欧美一区二区三区在线观看 | 超时空要爱国语完整版在线 | 亚洲欧美国产在线 | 亚洲天堂99 | 国产亚洲福利精品一区 | 国产日韩欧美精品在线 | 色姑娘色综合 | 秘书喂奶好爽一边 | 精品国产福利在线 | 五月激情丁香婷婷综合第九 | 亚洲福利一区 | 国产亚洲小视频 | 亚洲人成伊人成综合网久久 | 亚洲精品免费在线观看 | 午夜办公室在线观看高清电影 | 欧美les同性videos | 欧美春宫| 亚洲国内精品久久 | 成年男女免费视频 | 欧美日韩高清完整版在线观看免费 | 国产短视频精品一区二区三区 | 日韩精品中文字幕久久 | 幻女free性zozo交体内谢 | 免费看黄色大片 | 国产普通话对白露脸流出 |