LINEのパケットを見てみた
以下の方法でLINEのパケットを調べてみた。
- 起動後何もせず1分ほど待つ
- (起動時などはネットワーク制御系のパケットやら、アップデートやらの邪魔なパケットが飛び交いまくるので暫く待つ)
- WireSharkで使用中のネットワークインターフェースを指定する。
- すぐにLINEを立ち上げる(やることは3種類)
- 普通のメッセージを送る
- カスタムスタンプを送る
- 送り先で既読をつける(既読の戻りパケットが欲しい)
LINEっぽいホストをピックアップ
- 13.32.194.153 Amazon EC2(LINEのCDN)*1
- 203.104.142.52 LINE
- 203.104.150.2 LINE
- 23.45.140.69 アカマイ(LINEのCDN)
一番上は違うかも ちなみに、色分けルールもIP別に作成して解析しやすくした。
フィルタを使って通信を調べる
まずは全てのIPが含まれるフィルタ
ip.addr == 13.32.194.153 || ip.addr == 203.104.142.52 || ip.addr == 203.104.150.2 ||ip.addr ==23.45.140.69
通信の流れとしては
- No1: 最初に23.45.140.69と一回きりの通信(後は音沙汰なし)
- No2: 203.104.142.52と203.104.150.2を織り交ぜてチャットを実現?
- No3: 通信の後半に13.32.194.153から大きなデータを一方的に送りつけられている
という内容。(3の終了後に2のパケットのやり取りが何度かあった)*2
23.45.140.69 アカマイ
最初に通信をしていたのがこのホスト。
TLSを使って何かを送信している
最後の行がEncrypted Alertと表示されているが、下記サイトによると、
セッションの途中やキャッシュが残っている状態でキャプチャを開始して、前述の共通鍵が入手できず通信の中身が分からないときです。さて、SSLでは通信切断時はAlertプロコトルのClose Notifyで通知します。つまりタネあかしをすると、先ほどの謎のAlertは、単なるClose Notifyのパケットです。
とのことですが、それだと自分のキャプチャ結果のClose Notifyのパケットはサーバー側から出ているように思える。(Close Notifyはサーバー側、クライアント側どちらが出しても問題ないのかな?)
通信内容としては、一通りTLSのやり取りを行った後、ホスト・クライアント双方で400バイトくらいのデータを交換している。
個人的に思った感想としては明らかにアプリケーションが送付するデータよりTLSの制御パケットの方が圧倒的に多いこと。
TLSはまだ勉強不足なのでこのへんで・・・ ※またこれ以後のサーバーも全てTLSを使っていますが、TLSに関する説明は略します。
このサーバーとの通信は、最初にちょろっとTLS経由でデータ交換をした後、音沙汰なしのため最初に必要なアクションであるログイン認証をこのサーバーを使ってやっていると予測してみる
203.104.142.52
アカマイCDNとの通信が終わった後は、LINEのサーバーとの通信が始まる。 こちらは 203.104.150.2より先に通信が始まっている。 多分これはメッセージを送付する前に送られてきた情報、つまりLINEのアプリの状態自体(受信メッセージなどはあるか)などの情報を取りに行っている処理ではないだろうか?
203.104.150.2
こちらは203.104.142.52より後に通信が始まる。 また一部接続済みのコネクションで203.104.142.52から始まるパケットのまとまりもあるので(これは既読確認のパケット?)これはメッセージのためのサーバーなのではないか?
13.32.194.153 (LIneのCDN)
13.32.194.153側からこちらのクライアント側はTLSやTCPのメッセージしか送っていないが、 サーバー側から大量のパケットを受信している。 これは多分スタンプの画像データのダウンロードじゃないかな?と邪推してみる。
まとめ
完全に妄想の域を出ないけど、大体、以下のような動きになっているのではないか。
- 13.32.194.153 Amazon(LINEのCDN)はスタンプ配布のために利用
- 203.104.142.52 (LINEサーバー)はメッセージ送受信のために利用
- 203.104.150.2 (LINEサーバ)はアプリケーションの情報更新のために利用
- 23.45.140.69 アカマイ(LINEのCDN)はユーザーログインの認証のために利用
課題
やってる途中に思ったが、以下のことを試せばよかったと後悔。
- 通知
- 相手側からのメッセージの受信
多分もうやらないとおもうけど・・・*3