« gcc-sjljでビルドしたバイナリのデバッグ | トップページ | ココログでリキッドレイアウト »

2009/09/03

iPod touchのパケットをキャプチャする

 

無線LANアクセスポイント内蔵ブロードバンドルータ(以降、ルータと呼称)に接続しているWindows PCから、同じルータに接続しているiPod touch(やHT-03A, Nintendo DSなどのwifi機器)のパケット解析を行ってみた。利用したソフトウェアは以下の2つ。

 

今回の環境は右図の通り、local_network 通信を行う機器(以降、iPod)、通信をモニタする機器(以降、PC)とも、家庭で接続する一般的な形式であるが、この接続携帯でのパケットキャプチャ方法が解説されているサイトは少ないように思えた。

この接続形態では、iPodとPCはルータ(スイッチ)を介しており、iPodのパケットはPCに到達しない。ルータがパケットをどのポートに送ればよいか知っているためだ。

したがって、PCでiPodのパケットを受信するためには、ルータを騙してiPodのパケットを送ってもらう必要がある。

ここで、ARPスプーフィングという手法を用い、PCがiPodになりすませられるように、前述のCain&Abelを用いる。

設定方法は以下の通り。

  1. 画面上部のSnifferボタンを押しsnifferを開始する。
  2. 画面上部のSnifferタブへ移動する。
  3. 画面で右クリック>Scan Mac Addressを選択し、ホスト一覧を得る。chain01
  4. 画面下部のARPタブへ移動する。
  5. 画面上部の+アイコンをクリックすると設定ダイアログ”New ARP Position Routing”が開く。
  6. 設定ダイアログで、iPodとPCのアドレスをそれぞれ選択し、OKボタンで閉じる。
  7. 画面上部のARPボタンを押すと、ARPスプーフィング開始。chain02

この状態で、PC上のWiresharkをプロミスキャスモードでキャプチャ開始すると、iPodのパケットも取得できる。

wireshark01

iPodのパケットのみ取得したければIPアドレスでフィルタ(キャプチャフィルタ, 表示フィルタ)すれば良いだろう。

 

補足として、この状態ではiPodからのSSL通信が失敗してしまう。この問題については、Cain&AbelのメニューConfigureから起動できるダイアログのFilters and porsタブで、HTTPSのチェックを外すことで対応できた。

また、当然ではあるが、この方法ではiPodのSSL通信を解析することはできない。これについては、冒頭の図の中で、ルータとインターネット網の間にLinuxマシンなどで構成するプロキシサーバを経由させ、iPodに代わって自分(プロキシサーバ)が相手とSSL通信を行うことでキャプチャできると考えるが、環境が無いため試せていない。

 

参考:

« gcc-sjljでビルドしたバイナリのデバッグ | トップページ | ココログでリキッドレイアウト »

コメント

この記事へのコメントは終了しました。

トラックバック


この記事へのトラックバック一覧です: iPod touchのパケットをキャプチャする:

» iPhone/iPod touchアプリ [雪羽の発火後忘失]
マスタリングTCP/IP 入門編 第4版 竹下 隆史 村山 公保 荒井 透 苅田 幸雄 「高木浩光@自宅の日記」のエントリ「やはり退化していた日本のWeb開発者「ニコニコ動画×iPhone OS」の場合」を参考にして、iPhone/iPod touch版ニコニコ動画のパケットを見てみた。 準備 実行に用いたハード/ソフトは以下の通り。なお、接続環境は前回エントリと同様。 前出エントリで記載したWi... [続きを読む]

« gcc-sjljでビルドしたバイナリのデバッグ | トップページ | ココログでリキッドレイアウト »

other sites

  • follow us in feedly
  • github
  • stackoverflow

ソフトウェアエンジニアとして影響を受けた書籍

  • Christain Bauer: HIBERNATE イン アクション

    Christain Bauer: HIBERNATE イン アクション
    理論と実践が双方とも素晴らしい製品であるHibernate。本書はそのプロダクトを書名に冠していますが、Hibernateを使うつもりがなく、ORマッピングの解説書として読むにしても十分な良書です。Second EditionとしてJava Persistence With Hibernateという書籍も出版されていますが、残念ながら現在のところ 和訳はされていません。-インアクションは2.xの、Java Persistence-は3.1の頃のものなので、最新版とはちょっと違うところもあることに注意。 (★★★★★)

  • アンドリュー・S・タネンバウム: 分散システム 原理とパラダイム 第2版

    アンドリュー・S・タネンバウム: 分散システム 原理とパラダイム 第2版
    クライアント/サーバシステムを構築する上で必要となる知識が総論されてます。Web技術者も、フレームワーク部分を開発するのであれば必読。 (★★★★★)

  • Joel Spolsky∥著: ジョエル・オン・ソフトウェア

    Joel Spolsky∥著: ジョエル・オン・ソフトウェア
    前述の書籍「ソフトウエア開発プロフェッショナル」をより砕いたもの、という感じでしょうか。 前書きではプログラマでなくSE向けの本のように書かれているが、プログラマが読んでも面白い本であると思われます。 SEになった新人(あるいはそういう会社に入る/入りたての人)にとっては、これからどういったことが仕事を遂行していく上で起こりえるのか、どのように考えて行なっていけばいいのか決定する助けになると思います。 元は″Joel on Software″というブログの記事で、web上でも一部日本語で読めます。 http://japanese.joelonsoftware.com/ (★★★)

  • ドナルド・C・ゴース,ジェラルド・M・ワインバーグ: ライト、ついてますか

    ドナルド・C・ゴース,ジェラルド・M・ワインバーグ: ライト、ついてますか
    問題解決(一昔前のの流行語で言うところの『ソリューション』)能力は、システムエンジニアのスキルとして備えるべきもののうちのひとつです。しかし、これは難しい。学校で出されるテストと違い、唯一の、(問題提出者が想定している)解を求めるだけが「問題解決」では無いからです。そもそも、何が問題なのか、それは本当に問題なのか、それは本当に解決すべき問題なのか、その問題解決方法は正しいのか、などを解決しなければ、「その解は正しいのか」に辿りつくことができません。この本の最も良いところのひとつは、本があまり厚くないこと。すぐに読めるし、何回も読み返す気になるでしょう。 (★★★★★)

  • スティーブ・マコネル: ソフトウエア開発プロフェッショナル

    スティーブ・マコネル: ソフトウエア開発プロフェッショナル
    コードコンプリートで有名なスティーブマコネルの著書。新人SEに読んで欲しい。個人として業界の中でどうあるべきか、組織としてどうあるべきか、SEのプロ意識とは?SEの心構え概論、といったところでしょうか。また、業界における資格の重要性についても説かれています。この業界では資格が特に軽んじられる傾向がありますが、この傾向はどんな弊害をもたらすのか、将来的にこの業界は資格に対してどのような姿勢で臨んでいくべきなのか。日経BP社では(他の出版社もだが)最近、似たような類いのあまり面白くない書籍が乱出版されていますが、この本は別格だと思うので安心して購入して欲しいと思います。 (★★★★★)

無料ブログはココログ