-1

編集、フォーマットの変更、統計などの Wireshark ファイルのさまざまなことを行うために、Wireshark サービス (Wireshark にはいくつかのサービスがあります) を開くアプリケーションを構築しています。通常、各オプションは異なるサービスを使用するため、継承を使用してクラスを構築したいと考えています。私がやりたいことは適切な方法なのか適切な方法なのか疑問に思っていました:

次のメンバーとメソッドを持つメイン クラス WiresharkServices: これは、他のすべてのクラスが継承する必要があるクラスです。

public class WiresharkProcesses
{
    protected string _filePath; //the file path who send to Wiresahrk process
    protected string _capinfos;
    protected string _dumpcap;
    protected string _editcap;
    protected string _mergecap;
    protected string _rawshark;
    protected string _text2pcap;
    protected string _tshark;
    protected string _wireshark;

    public void initializeServices()
    {
        if (Directory.Exists(@"C:\Program Files (x86)\Wireshark"))
        {
            _capinfos = @"C:\Program Files (x86)\Wireshark\_capinfos.exe";
            _dumpcap = @"C:\Program Files (x86)\Wireshark\_dumpcap.exe";
            _editcap = @"C:\Program Files (x86)\Wireshark\editcap.exe";
            _mergecap = @"C:\Program Files (x86)\Wireshark\_mergecap.exe";
            _rawshark = @"C:\Program Files (x86)\Wireshark\_rawshark.exe";
            _text2pcap = @"C:\Program Files (x86)\Wireshark\_text2pcap.exe";
            _tshark = @"C:\Program Files (x86)\Wireshark\_tshark.exe";
            _wireshark = @"C:\Program Files (x86)\Wireshark\_wireshark.exe";
        }
        else if (Directory.Exists(@"C:\Program Files\Wireshark"))
        {
            _capinfos = @"C:\Program File)\Wireshark\_capinfos.exe";
            _dumpcap = @"C:\Program Files\Wireshark\_dumpcap.exe";
            _editcap = @"C:\Program Files\Wireshark\editcap.exe";
            _mergecap = @"C:\Program Files\Wireshark\_mergecap.exe";
            _rawshark = @"C:\Program Files\Wireshark\_rawshark.exe";
            _text2pcap = @"C:\Program Files\Wireshark\_text2pcap.exe";
            _tshark = @"C:\Program Files\Wireshark\_tshark.exe";
            _wireshark = @"C:\Program Files\Wireshark\_wireshark.exe";
        }
    }
}

アプリケーションが実行されているとき、私はもちろん、マシンに Wireshark がインストールされているかどうかを確認します。例外がスローされず、Wireshark に存在しない場合は、次のようにチェックします。

WiresharkServices wservices = new WiresharkServices();
wservices .initializeServices();

そして、各クラスには独自のメソッドがあります。

ファイル パスを受け取って他の Wireshark 形式に変換する子クラスの例:

public class Editcap : WiresharkProcesses
{
    private string _newFileName;

public void startProcess(string filePath)
{
    FileInfo file = new FileInfo(filePath);
    _newFileName = file.FullName.Replace(file.Extension, "_new") + ".pcap";
    ProcessStartInfo editcapProcess = new ProcessStartInfo(string.Format("\"{0}\"", _editcap))
    {
        Arguments = string.Format("{2}{0}{2} -F libpcap {2}{1}{2}", file.FullName, _newFileName, "\""),
        WindowStyle = ProcessWindowStyle.Hidden,
        RedirectStandardOutput = true,
        RedirectStandardError = true,
        CreateNoWindow = true,
        UseShellExecute = false,
        ErrorDialog = false
    };

    using (Process editcap = Process.Start(editcapProcess))
    {
        editcap.WaitForExit();
    }
}

public string getNewFileName()
{
    return _newFileName;
}

}

4

1 に答える 1

0
public void initializeServices()
{
    string programFilesDirectory = "";

    if (Directory.Exists(@"C:\Program Files (x86)\Wireshark"))
        programFilesDirectory = @"C:\Program Files (x86)\";

    else if (Directory.Exists(@"C:\Program Files\Wireshark"))
        programFilesDirectory = @"C:\Program Files\";

    _capinfos = programFilesDirectory + @"_capinfos.exe";
    _dumpcap = programFilesDirectory + @"_dumpcap.exe";
    _editcap = programFilesDirectory + @"editcap.exe";
    _mergecap = programFilesDirectory + @"_mergecap.exe";
    _rawshark = programFilesDirectory + @"_rawshark.exe";
    _text2pcap = programFilesDirectory + @"_text2pcap.exe";
    _tshark = programFilesDirectory + @"_tshark.exe";
    _wireshark = programFilesDirectory + @"_wireshark.exe";

開始するために変更してください...

于 2012-12-11T16:16:54.217 に答える