伺服器抓包知識

来源:https://www.cnblogs.com/tiezhuxiong/archive/2022/07/13/16474008.html
-Advertisement-
Play Games

編寫背景: 本人負責某銀行的一個項目主力開發,在與第三方調試介面時遇到了一個問題:對方伺服器明明給了我返回的值,但我這邊卻沒有收到,日誌中沒有列印對應的值。一開始我認為是對方的問題,但是對方就丟了一句“我試了有的”,然後我就一個人風中凌亂。 隨即我就想到了抓包的方式進行驗證,看到底是哪一方的問題導致 ...


編寫背景:

本人負責某銀行的一個項目主力開發,在與第三方調試介面時遇到了一個問題:對方伺服器明明給了我返回的值,但我這邊卻沒有收到,日誌中沒有列印對應的值。一開始我認為是對方的問題,但是對方就丟了一句“我試了有的”,然後我就一個人風中凌亂。

隨即我就想到了抓包的方式進行驗證,看到底是哪一方的問題導致的。因為日誌可能會騙人,但是抓包是不會的。

抓包的概念:

抓包顧名思義就是抓取數據包,基本上與第三方通訊就會產生數據包,我們將這些包做了一個抓取的動作,將它保存在我們指定的文件中。我們與第三方的交互走的是TCP,且無加密,所以我們只需要簡簡單單的抓包解析數據即可。

 

抓包前的準備:

 

首先要想在伺服器中使用抓包指令就需要安裝對應的抓包工具tcpdump”,大部分伺服器上是沒有的,需要自行安裝,只有安裝了之後才能使用tcpdump的指令,安裝的教程直接百度搜一下“tcpdump安裝”即可。

 

準備好測試的數據,因為抓包的速度非常快,而且抓的東西也比較多,如果你的伺服器有其他應用去交互,可能會因為你的數據準備不充足導致你執行了抓包指令後大半天做不完交易,到時候抓出來的包非常笨重,且不方便查看。我的建議是自己估摸好發交易的節點,在節點前一步再執行抓包指令。

 

下載一個叫做Wireshark工具,這個工具專門用來解析抓包後的文件,工具的安裝及使用教程就自己百度了。

 

要得到伺服器的ROOT用戶密碼,因為tcpdump指令只能是root用戶下操作。

 

 

開始抓包:

1、登錄伺服器,使用root用戶;

2、在發起交易的前一步就要執行抓包指令;

3、在任意目錄下執行 tcpdump -i any -XO -vvv -s0 -w /root/anyport.cap

 

root/anyport.cap  這個是文件保存的路徑,可以自己定義。

4、執行完交易後,馬上在伺服器按CTRL+C停止抓包,否則會無限抓包,這個十分重要一定要牢記;

解析數據包:

1、在伺服器路徑中取出剛抓包的文件;

2、將文件丟進Wireshark工具中;

3、在工具上方的輸入框中輸入ip.addr=xxx.xxx.xxx.xx 可以直接定位對方ip地址的數據;

 

 

4、找到對方返回的報文內容;

 

 

5、很驚奇的發現居然是亂碼,這個其實是和內容編碼有關係,如果編碼是UTF-8之類的常見編碼則可以正常解析出來,但是項目採用的是cp937這類編碼,則就需要進行轉換了。如果你的解析沒有亂碼,下麵的內容對你意義不大了。

6、複製返回報文的hex值,選擇 hex stream

7、在java中寫一個轉換的方法,對數據進行轉換。具體代碼我附上,解釋在代碼中註解;

package test;

import java.io.UnsupportedEncodingException;



public class test {
    
    public static void main(String[] args) throws UnsupportedEncodingException {
        /*將抓包到的hex值粘貼進來*/
        byte[] teststr=hexToByteArray("40f0f5f7f44040f0f0f0f4f5f040404040404040404040404040404040f0f0f0f0404040404040f0f0f3f0f0f5f0f0f2f3f3f5f0f0f9f9f9f9f0f7f7f0f7f9f0f0f0f0f0f0f0f0f0404040404040404040f0f0f640f0f0f0f0f0f0f0f0f0f1f0f0f0f0f0f0f0f0f0f0f0f0f0f0f04040404040404040404040404040404040f0f3404040404040404040404040404040404040404040404040404040404040404040404040404040404040404040404040404040404040404040404040404040404040404040404040404040404040404040404040404040404040404040404040404040404040404040404040404040404040404040404040404040404040404040404040404040404040404040404040404040404040404040404040404040404040404040404040404040404040404040404040404040404040404040404040404040404040404040404040404040404040404040404040404040404040404040404040404040404040404040404040404040404040404040404040404040404040404040404040404040404040404040404040404040404040404040404040404040404040404040404040d4c1c3c1e440c2d6c340e3c5e2e340c1c3c3d6e4d5e34040404040404040404040404040404040404040404040404040404040404040404040404040404040404040404040404040404040404040404040404040404040404040404040404040404040404040404040404040404040404040404040404040404040404040404040404040404040404040404040404040404040404040f1f3f8");
        System.err.println(new String(teststr,"cp937"));//指定對應的編碼轉String
    }
    /** 
     * Hex字元串轉byte 
     * @param inHex 待轉換的Hex字元串 
     * @return  轉換後的byte 
     */  
    public static byte hexToByte(String inHex){  
       return (byte)Integer.parseInt(inHex,16);  
    }  
    public static byte[] hexToByteArray(String inHex){  
        int hexlen = inHex.length();  
        byte[] result;  
        if (hexlen % 2 == 1){  
            //奇數  
            hexlen++;  
            result = new byte[(hexlen/2)];  
            inHex="0"+inHex;  
        }else {  
            //偶數  
            result = new byte[(hexlen/2)];  
        }  
        int j=0;  
        for (int i = 0; i < hexlen; i+=2){  
            result[j]=hexToByte(inHex.substring(i,i+2));  
            j++;  
        }  
        return result;   
    }   
  
   
}

 

 

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 今天用Flask + MySQL 實現用戶註冊,登錄和登出。 一、實戰場景 Flask 框架實現用戶的註冊,登錄和登出。 二、主要知識點 flask_login 插件使用 SQLAlchemy 基礎操作 用戶基礎類設計 Flask 讀取配置文件 藍圖註冊與使用 wtforms 表單提交數據 wtfo ...
  • 1. 函數 在python中,函數通過def關鍵字、函數名和可選的參數列表定義。通過return關鍵字返回值。我們舉例來說明如何定義和調用一個簡單的函數: >>> def foo(): ... return 1 >>> foo() 1 方法體(當然多行也是一樣的)是必須的,通過縮進來表示,在方法名的 ...
  • 作者:小牛呼嚕嚕 | https://xiaoniuhululu.com 電腦內功、JAVA底層、面試相關資料等更多精彩文章在公眾號「小牛呼嚕嚕 」 Java對象究竟是什麼? 對象:對象是類的一個實例,有狀態和行為。 類:類是一個模板,它描述一類對象的行為和狀態。 例如 人 是一個類 其狀態有:姓 ...
  • Map下的介面及其多個實現類 1.Map :雙列數據存儲key-value對的數據, 類似於高中弄的函數:y=f(x) (1)HashMap:作為map的主要實現類,線程不安全的,效率高,存儲在null的key-value ①存儲在null的key和value如下圖所示 LinkedHashMap: ...
  • 前言:前言不重要,linq入門常用的語法,linq語法可以用來寫操作集合、資料庫表集合等等幾乎所有集合類型的操作。下麵就寫幾個案例(以List集合來做的),看代碼和運行結果即可。 本文演示環境:VS2022 + .NET 6 1、創建一個.NET 6.0的控制台項目,用來演示測試和輸出。 2、然後新 ...
  • 初學Bash時, 我從未想過去debug Bash腳本, 也從未想過Bash腳本也能debug. 隨著技術的增長, 寫的腳本越來越複雜, 使用echo列印日誌來調試腳本的方式越來越捉襟見肘了. 直到某天 通讀了一遍Bash Reference Manual, 才發現Bash腳本也是可以debug的. ...
  • 鏡像下載、功能變數名稱解析、時間同步請點擊 阿裡雲開源鏡像站 問題描述: window上複製的內容無法粘貼在Linux上 環境 window64位 Ubuntu18.04 解決步驟 1、直接在命令行執行以下命令 sudo apt-get autoremove open-vm-tools //卸載已有的工具 ...
  • App Cleaner Pro是一款Mac上非常好用的軟體卸載工具,支持應用卸載、Widget卸載、瀏覽器插件卸載,支持拖拽卸載和列表卸載,能夠非常乾凈的卸載應用,節省你的磁碟空間。 詳情:App Cleaner & Uninstaller for Mac(應用程式清理卸載工具) 功能介紹 1、掃描 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...