伺服器抓包知識

来源: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
  • 示例項目結構 在 Visual Studio 中創建一個 WinForms 應用程式後,項目結構如下所示: MyWinFormsApp/ │ ├───Properties/ │ └───Settings.settings │ ├───bin/ │ ├───Debug/ │ └───Release/ ...
  • [STAThread] 特性用於需要與 COM 組件交互的應用程式,尤其是依賴單線程模型(如 Windows Forms 應用程式)的組件。在 STA 模式下,線程擁有自己的消息迴圈,這對於處理用戶界面和某些 COM 組件是必要的。 [STAThread] static void Main(stri ...
  • 在WinForm中使用全局異常捕獲處理 在WinForm應用程式中,全局異常捕獲是確保程式穩定性的關鍵。通過在Program類的Main方法中設置全局異常處理,可以有效地捕獲並處理未預見的異常,從而避免程式崩潰。 註冊全局異常事件 [STAThread] static void Main() { / ...
  • 前言 給大家推薦一款開源的 Winform 控制項庫,可以幫助我們開發更加美觀、漂亮的 WinForm 界面。 項目介紹 SunnyUI.NET 是一個基於 .NET Framework 4.0+、.NET 6、.NET 7 和 .NET 8 的 WinForm 開源控制項庫,同時也提供了工具類庫、擴展 ...
  • 說明 該文章是屬於OverallAuth2.0系列文章,每周更新一篇該系列文章(從0到1完成系統開發)。 該系統文章,我會儘量說的非常詳細,做到不管新手、老手都能看懂。 說明:OverallAuth2.0 是一個簡單、易懂、功能強大的許可權+可視化流程管理系統。 有興趣的朋友,請關註我吧(*^▽^*) ...
  • 一、下載安裝 1.下載git 必須先下載並安裝git,再TortoiseGit下載安裝 git安裝參考教程:https://blog.csdn.net/mukes/article/details/115693833 2.TortoiseGit下載與安裝 TortoiseGit,Git客戶端,32/6 ...
  • 前言 在項目開發過程中,理解數據結構和演算法如同掌握蓋房子的秘訣。演算法不僅能幫助我們編寫高效、優質的代碼,還能解決項目中遇到的各種難題。 給大家推薦一個支持C#的開源免費、新手友好的數據結構與演算法入門教程:Hello演算法。 項目介紹 《Hello Algo》是一本開源免費、新手友好的數據結構與演算法入門 ...
  • 1.生成單個Proto.bat內容 @rem Copyright 2016, Google Inc. @rem All rights reserved. @rem @rem Redistribution and use in source and binary forms, with or with ...
  • 一:背景 1. 講故事 前段時間有位朋友找到我,說他的窗體程式在客戶這邊出現了卡死,讓我幫忙看下怎麼回事?dump也生成了,既然有dump了那就上 windbg 分析吧。 二:WinDbg 分析 1. 為什麼會卡死 窗體程式的卡死,入口門檻很低,後續往下分析就不一定了,不管怎麼說先用 !clrsta ...
  • 前言 人工智慧時代,人臉識別技術已成為安全驗證、身份識別和用戶交互的關鍵工具。 給大家推薦一款.NET 開源提供了強大的人臉識別 API,工具不僅易於集成,還具備高效處理能力。 本文將介紹一款如何利用這些API,為我們的項目添加智能識別的亮點。 項目介紹 GitHub 上擁有 1.2k 星標的 C# ...