簡體   English   中英

監視來自特定端口的所有傳出/傳入數據包

[英]Monitor All outgoing/Incoming packet from a specific port

我試圖監視端口以使用Java從我的PC中獲取傳出/傳入數據包(或套接字),更像Wireshark所做的那樣。

我正在使用此代碼:

int portNumber = 5816;

        try {
            System.out.println("New ServerSocket...");
            ServerSocket serverSocket = new ServerSocket(portNumber);
            serverSocket.setSoTimeout(5000);

            System.out.println("Accepting...");
            serverSocket.accept();

            System.out.println("Done Accepting.");
        } catch (IOException e) {
            System.out.println(e.getMessage());
        }

現在,我可以使用Wireshark看到數據包,並且可以看到使用Process Hacker 2建立了連接,但是我總是得到以下輸出:

新的ServerSocket ...接受...接受超時

編輯:問題,我安裝了一個應用程序,可以與外部服務器(也不是我的客戶端或服務器)交換數據包,我只想攔截這些數據包並記錄它們。 他們正在使用5816端口。

Wireshark正在使用pcap庫來攔截網絡通信。 您可以使用Java的pcap包裝器來實現類似的功能。

注意:
您沒有關閉套接字。 但是,此代碼仍然不是實現目標的錯誤方法。

    int portNumber = 5816;

    System.out.println("New ServerSocket...");        
    try (ServerSocket serverSocket = new ServerSocket(portNumber)) {
        serverSocket.setSoTimeout(5000);

        System.out.println("Accepting...");

        try(Socket socket = serverSocket.accept()) {
            System.out.println("Done Accepting.");
        }

    } catch (IOException e) {
        System.out.println(e.getMessage());

    }

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM