久久r热视频,国产午夜精品一区二区三区视频,亚洲精品自拍偷拍,欧美日韩精品二区

您的位置:首頁技術(shù)文章
文章詳情頁

如何劫持Java應(yīng)用的HTTP請求

瀏覽:12日期:2022-08-22 13:56:19

背景

全鏈路追蹤中,針對部分特殊的流量,希望將它引導(dǎo)到特定服務(wù)上(這個特定服務(wù)不在正常請求的鏈路上)——問題可以被抽象為解決進程間通信過程中目標進程的選擇。

進程間通信方式很多,本篇只關(guān)注 Java 進程間套接字通信下 HTTP 形式的請求劫持,引導(dǎo)特定流量到特定進程。

解決方案

可行的處理方案繁多。自頂向下從應(yīng)用、框架、JVM、Container Runtime、System Call、網(wǎng)絡(luò)協(xié)議棧等級別,均可著手解決。侵入性最強的操作就是要求所有業(yè)務(wù)應(yīng)用都主動實現(xiàn) HTTP 請求分流邏輯;次一級是提供二方庫供業(yè)務(wù)應(yīng)用主動集成;或者從系統(tǒng)層面進行改造,基于改寫系統(tǒng)調(diào)用對請求進行劫持。

回顧兩年前的所學,JVM TI 為劫持 HTTP 請求提供了一個全新的解決思路。通過 Agent 改寫應(yīng)用啟動時加載的類的字節(jié)碼,劫持類的實例并完成目標功能。

由于 Java 項目間調(diào)用大量的使用了 Apache 的 http-client 庫,改寫變得相當簡單。識別流量,并對特定流量改寫請求的 Host 即可。

Demo

由于 http-client 對所有請求目標都統(tǒng)一由 org.apache.http.HttpHost 維護,控制變得極為簡單。只需在 HttpHost 實例化時,改寫類的構(gòu)造方法,即完成了對目標的劫持工作(下例中強制將所有請求指向 163.com)

public class Agent implements ClassFileTransformer { public static void premain(String args, Instrumentation instrumentation) { instrumentation.addTransformer(new Agent()); } @Override public byte[] transform(ClassLoader loader, String className, Class<?> classBeingRedefined, ProtectionDomain protectionDomain, byte[] classfileBuffer) throws IllegalClassFormatException { if ('org/apache/http/HttpHost'.equals(className)) { ClassPool pool = ClassPool.getDefault(); try {CtClass httpHost = pool.get('org.apache.http.HttpHost');CtClass string = pool.get('java.lang.String');CtConstructor constructor = httpHost.getDeclaredConstructor(new CtClass[]{string, CtClass.intType, string});constructor.insertBefore('hostname = 'www.163.com';');byte[] bytes = httpHost.toBytecode();FileOutputStream fos = new FileOutputStream('/Users/fangfeng/a.class');fos.write(bytes);return bytes; } catch(NotFoundException | CannotCompileException | IOException e){e.printStackTrace(); } } return classfileBuffer; }}

將整個項目打包為 agent.jar 的過程不做太多介紹,詳見 ffutop/http-client-plugin

針對需要劫持的項目,在啟動參數(shù)中增加 -javaagent:${PATH_TO}/http-client-plugin.jar

以上就是如何劫持Java應(yīng)用的HTTP請求的詳細內(nèi)容,更多關(guān)于劫持Java應(yīng)用的HTTP請求的資料請關(guān)注好吧啦網(wǎng)其它相關(guān)文章!

標簽: Java
相關(guān)文章:
主站蜘蛛池模板: 西和县| 西宁市| 东台市| 正镶白旗| 西乡县| 眉山市| 阿克苏市| 会东县| 潮安县| 华安县| 昌黎县| 炎陵县| 嘉兴市| 达州市| 闵行区| 定结县| 绥芬河市| 罗甸县| 怀柔区| 白山市| 桂阳县| 温宿县| 苗栗县| 女性| 靖宇县| 襄汾县| 德清县| 陈巴尔虎旗| 井研县| 河池市| 宜城市| 湖北省| 滨州市| 舟山市| 科技| 凤冈县| 淮阳县| 井冈山市| 驻马店市| 嘉义市| 栖霞市|