2012-04-19 11 views
1

wiresharkがMac OSX環境でluaスクリプトを正しく処理するように設定する必要がある初期設定はありますか?Wireshark LuaディシジョンスクリプトをMac OSXに移植する方法は?

「パケットのHTTPヘッダー長を調べる方法」の質問にLuaの回答を移植しようとしました。 https://stackoverflow.com/a/5794357/1217670

Macで動作するソリューションを取得できませんでした。

解決策は、Wireshark 1.6.7、Lua 5.1のWindows XPプラットフォームで正常に動作しました。

Wireshark 1.6.5、Lua 5.1を使用してMac OSX 10.7.3上でhttp_extra.luaスクリプトを実行します。 [Header Length(bytes):917]ヘッダーフィールドは表示されません。
カスタムHTTPヘッダーフィールドにhttp.hdr_lenを入力しました。

http.hdr_lenでフィルタリングすると、何も表示されません。

http_extra.luaスクリプトは、 /Applications/Wireshark.app/Contents/Resources/lib/wireshark/pluginsディレクトリに配置されています。
スクリプトをPersonal Plugins Folderに移動した場合と同じ結果になります。

これは、Windows XPシステムで完全に動作するスクリプトファイルです。

About Wireshark Pluginsタブには、http_extra.luaがタイプluaスクリプトとしてリストされています。

スクリプトをテストしてエラーを作成すると、wiresharkがスクリプトを認識していることが検証されます。

LUA_PATHをグローバルプラグインディレクトリに設定する必要があります。これは効果がありませんでした。

ご意見をお寄せください。

答えて

1

Wiresharkの - プリファレンス - プロトコル - HTTPパネルをチェックすべての4つのボックスを有していなければならない:スパニング

  1. 再度組み立てHTTPヘッダーを複数のTCPセグメント
  2. 再度組み立て複数のTCPセグメントにまたがるHTTP本体
  3. Reassembl eチャンクされた転送コード本体
  4. エンティティボディの圧縮を解除します。

Mac環境はWindowsの設定と一致し、[Header Length(bytes):917]を示す同じ結果が得られます。

プラグインをグローバルまたはローカルのプラグインディレクトリに配置するのと同じ結果になります。

Mac osx Luaプラグインディレクトリのパスの場所は、About Wiresharkパネル - フォルダタブに記載されています。

2

OSX上の個人Wiresharkのプラグインディレクトリは次のとおりです。それはかもしれ古いWiresharkのバージョンの場合

~/.config/wireshark/plugins 

:あなたのケースでは

~/.wireshark/plugins 

、中のLuaスクリプトを置く:

~/.config/wireshark/plugins/http_extra.lua 

ルア初期パスの詳細については、これらの記事を参照してください:

+0

私はこの同じ結果を試しました。私が気づいたことの1つは、wiresharkフィルタ式ボックスのフィールド名は次のとおりです。http.header.http.hdr_len - http.hdr_len(ヘッダー長(バイト))? ?これは間違っています?構成を再チェックする必要があります。 – phil

+0

ディスプレイフィルタのテキストボックスが赤色(緑色ではなく)で表示されている場合は、無効なフィールドを含む構文エラーがあることを意味します。プラグインが実際にロードされていることを確認してください:print文をLuaファイルの先頭に置き、コマンドラインからWiresharkを再起動して、プリントアウトを確認してください。 –

+0

これにより、フィルター式が誤って作成されました。 「カスタムHTTPヘッダーフィールドにhttp.hdr_lenを入力しました。」カスタムhttpフィールドのエントリを削除し、不正な値が消えました。ディセクターはこのフィールドヘッダーを設定します。 – phil

関連する問題