Android 2.2 FroyoでSoftbank MMS対応する方法(Mms.apk)

Mms.apk.froyo.jakeMod5に更新しました。(2010/8/2)

Mms.apk.froyo.htc.jakeModExperimental4 アップしました。(2010/8/6)

Android 2.1 (Eclair)をお使いの場合はこちら

Android 2.2のソースコードがいよいよ公開されたということで、Softbank MMS対応すべくさっそく AOSP(Android Open Sourcee Project)からFroyoのソースを取得してビルドしてみました。

ソースコードを概観したところの感想は次のようなものです。

  • Softbank MMSの問題を引き起こしていた部分は、EclairでのAOSPの有志の方のコミットにもかかわらず反映されていないようでした。
  • 特にFrameworks.jarに含まれる Pdu関連のソースは手つかずのままFroyoに持ち越されている様子。
  • Mms.apkについては、いろいろ手が加わっており、Eclairでの些細なバグなど(文字化けとか)が修正されていました。
Eclairのソースで施した手当と同じことをFroyoに施してコンパイルしなおしました。チャレンジャーの皆様の役に立てばと思います。

CyanogenMod6をお使いなら

CyanogeMod 6 ROMをお使いの場合は、なにもしなくてもSoftbankでも利用可能です。当方のMms.apkと置き換えるメリットを考慮の上判断してください。

OpenDesire 3.0.x以上をお使いなら

UserAgent指定などのオプションや、SoftbankのMMSを利用するための最小限の更新が含まれています。

当方のMms.apkを利用するメリット

ROMの更新や各方面の方々の対応、Softbank本家の対応予定など、当方での仕事も役目を終えつつありますが、現時点でなおも当方のMms.apkを利用するメリットとしては次のような点になります。
  • アプリ間の連系で emailto: URL Intent を受け取れるように設定しています。
  • Eメールアドレスで送受信した場合のコンタクトのアイコンやアドレスの新規登録処理で、ちゃんと電話番号の場合と区別して処理されるようになっています。
  • HTC由来のROMをご利用の場合
    ソフトバンク本家の謹製アプリが出るまでは、当方で特別対応したものが有効だと思われます。

Mms.apk置き換え時とその後の手順

rootを取る手順や Mms.apk を置き換える手順については各方面で紹介されているのでここでは省略します。

Mms.apkファイルをインストールするとき

/system/app/Mms.apk ファイルを置き換えます。同じディレクトリに Mms.odex ファイルが存在する場合は必ず削除します。

Mms.apkファイルを置き換えて再起動後

User-Agentの設定を必ず行ってください。ソフトバンクで使用する場合はこれを行わないと始まりません。


それでもうまくいかない場合・・・
  • 「モバイルネットワーク」設定(APN設定)でMMSの設定はできていますか?
  • User-Agentの設定をいろいろ変えてもだめですか?


ダウンロード
Mms.apk.froyo.jakeMod5
  • chanogenの更新の取り込み(フォントサイズ指定など微小な修正)
Mms.apk.froyo.jakeMod4
  • AvatorのEmailアドレス対応の修正
  • 文字の大きさ設定、名前を表示しない設定の追加
  • cyanogenからの追加(言語リソースの追加)
Mms.apk.froyo.jakeMod3
  • 背景黒のオプション追加(cyanogenでの更新の反映) (2010/7/9までの分)
Mms.apk.froyo.jakeMod2
  • cyanogenでの新しい更新を含む(2010/6/30までの分)
Mms.apk.froyo.jakeMod1
  • multipart/alternative のメールが文字化けしていたのを修正。(当方のeclairのソースからのコピーミス)



 

HTC由来のROMの注意

なおHTC由来のROM(Sense UI付のもの)では上記のMms.apk では正常動作しません.
たとえば以下のようなROMは HTC 由来のものとなります。
  • LeeDrOiD
  • Oficial Froyo HTC Sense ROM
  • DJ DROID。
以下に試験的に作成したバージョンを置いておきます。

Mms.apk.froyo.htc.jakeModExperimental4
  • メッセージの送信で落ちる不具合に対処(できたか不明動作報告求む)

 

Mms.apk.froyo.htc.jakeModExperimental4 (871 kb)

 

Softbank X06HT のMMS対応の方法(予想)

当方の海外購入版 SIMフリー HTC DesireではROOT化とMMSアプリの書き換えで Softbankが公式に非対応としている S!メール に対応することができました。

公式にはSoftbankは近々アップデートで対応するといっているのですが、果たしてどういった対応をしてくるのでしょうか。対処しなければならない問題箇所を予測してみました。

Softbankの MMS 拡張プロトコルの問題

MMSの送受信でDocomoのユーザーの被害(?)が少ないのは多くはこれによっていたと思われます。SoftbankのMMSセンターを通じて送られるMMSデータの中にSoftbank(Vodafone?)が独自に拡張したプロトコルが含まれており、これを正しく扱えなかった Android OS のライブラリが例外を起こして落ちるために受信に失敗していました。解決法には、Android OS側のプログラムをそういったイレギュラープロトコルを正しく無視するか取り扱うように補強する方法と、SoftbankのMMSセンター側で、Androidに対しては拡張されたデータ部分を送信しないようにするという道があります。しかしながら、MMSセンターは、アクセスの拒否の判断を User-Agent を使って行っているようですが、User-Agentによって送信するデータを変えるというのははたして簡単なのか。すでに、User-Agentの偽装は多くの方ができるようになっており、将来の問題追跡の煩雑化を考えると技術者目線ではやりたくない方法です。もっとも、Vodafoneなんちゃらという標準を逸脱するヘッダーを拡張仕様として乗っけた時点で技術側負けだったのだと思いますが。

Android OS自身に内在する不具合

上記のSoftbank固有のプロトコル意外にも、MMSのプロトコルの取り扱いに関しては framework.jar という共有のライブラリに格納された部分にマルチパートのメールを正常に扱えないなどの問題を含んでおり、これはいずれにしてもアップデートして解消しなければなりません。Mms.apkというパッケージ自身もシステム上でロックされて上書きできないようにされているわけですから、framework.jar という共有ライブラリの更新はさらに大変そうです。結局はROMの更新しかないと思われるわけです。

Softbankとして独自に追加的にやらないといけないこと

  • 絵文字対応
    日本のガラパゴス携帯に合わせるためにやらないといけない。白黒ならフォントの置き換えで対応できるが、やはり謹製クオリティを出すならカラー絵文字でないといけない。
  • HTMLメール対応
    いわゆるデコメールなどと呼ばれているもの。HTMLブラウザを引っ張ってこないといけないので、Mms.apkの拡張という意味では荷の重い工程になるはずです。
  • 日本人的に使いやすいUIをもったアプリの提供
    Android標準のメッセージソフトは海外の人が使い慣れた「1行SMS」的使い方に特化されたデザインになっているので、日本のユーザー向けにはやはり個別のメールアプリを提供したほうがいいのでしょうが、Softbank自身にそういった開発をする意欲があるかどうか疑問です。余計なコストになるので、Mms.apkを問題のない程度に変更したものを入れてくるだけになるかもしれません。

マーケットからの単独アプリとして提供する場合の困難

2010年7月現在ソフトバンクからは単独アプリとしてマーケットからMMSアプリを提供するとアナウンスされています。Mms.apkを上書きインストールする形になるのか、別アプリとしてインストるするかのいずれかになるのでしょうか…。もっともMms.apkをrootを取らなくても上書きインストールすべがあるのなら多くの人がRootを取ったり、ADBを使用したりこんなに苦労しなくても済むのです。

もともとAndroidに含まれている Mms.apk は /system/app というディレクトリに格納されており、一方で通常後からインストールされるアプリは /data/app というディレクトリに配置されます。/system/appディレクトリは文字通りシステムによって保護されており、ここに入っているアプリは「root」を取らずして削除したり、上書きしたりすることができません。

AndroidのアプリはIDによって識別されています。(たとえば mms.apk は com.android.mms など)このIDを違うものを指定することで、原理的には2つ目のMms.apkをインストールすることができます。そこで2つ目のMms.apkを使用するようにすればいいとなるかといえばそう簡単ではありません。Mms.apkアプリはメッセージ関連のイベントを処理するためのバックグランドプロセスとしても登録されています。また、アプリ間の連携のため電話番号やEメールアドレスをキャッチするための登録もされています。これらを別のアプリから横取りすることはある意味「安全」な方法でやるのは無理です。(と思います)

そういう点で「別アプリ」提供の場合、Mms.apkの改良や延長という対応ではなく、iPhone が i.softbank.ne.jp でやったようなSMS/MMSとは完全に別体系のアプリとなるのではないかと思います。

いずれにしても、今後の展開が楽しみです。

 

HTC Desire(X06HT)で Softbank MMS対応する方法 Mms.apkの差し替え

2010/7/3 Mms.apk.jakeMod11アップしました。

Softbank X06HT(HTC Desire)の登場で、思わず衝動買いしそうになりつつ、ネットを調べるとどうもSIMフリーを海外から購入したほうが(エンジニア魂をくすぐる問う意味で)いろいろお得感が大きいという結論になり、さっそく購入しました。在庫有りだったためなんと香港からFedexで1日で届いてしまいました。

Softbankのアナウンスでは当初はMMSやメール送受信(Y!メールという?)はできないということでしたが、なんのそれくらいいいやと踏んでいたところ、それがいかに足かせになろうとは思ってもいませんでした。いろいろ触るうちに、どうしてもこれをメインの携帯として使いたいという欲がムラムラとこみあげてきて、ついに意地でもMMS対応させようと HTC DesireのROOT化、Andoid標準のメッセージソフトの更新に踏み込みました。

Android OS 2.1に関する話題はいろんなところでされているので、ここでは私個人の都合状どうしてもやらなければならなかったことをメモとして残しておこうと思います。

SMS/MMSにまつわる解決できなかった問題

  • UserAgent問題
    当初、SoftbankのMMSの接続ができない問題が持ち上がったときにこの UserAgent の偽装をおこなうことで送受信できるようになるといわれました。そこで、各所でUserAgentを選択的に偽装できる修正がなされたMms.apk ファイルが作られて配布されました。が、後に続く問題のために、どうしても実用的なレベルに使用できませんでした。
  • 本文に漢字が含まれるとメッセージが届かなかったり、件名と本文がぶっ飛んだりしてしまった
    メッセージが通知もされず届かないという問題は致命的でした。
  • 画像などの添付ファイルがあるとやはりおかしかった
  • 改行キーでメッセージを送信するとメッセージが同じもの2通が送信されてしまう
  • ファイル名としてふさわしくない文字列を含む添付ファイルを保存しようとするとできない。
  • 件名に日本語を含んだメッセージを「書きかけ」としていったん保存すると再度の編集時、件名が文字化けする。

その1:ROOT化

Androidのシステムに標準に組み込まれているソフトは通常のアプリのインストール方法なで上書きやアップデートがかけられないようにロックされています。つまり、OS上でROOT権限がないとこれらのコンポーネントの変更・削除ができないことになります。

そこで、俗に言われるROOT化という禁断の手が必要になります。この作業はご存じのとおり、メーカーの保証や各所のサポートを受けられなくしてしまう禁じてであるのでおいそれとはすすめられません。また、この方法についてはここでは省略しますので、関係各所を参考の上チャレンジしてください。

Googleの検索結果

その2:APN問題

SIMフリー版など、携帯キャリアのものでないデバイスを使用する場合について回る問題です。通話やSMSは何もしないでもSIMを差し替えるだけで使えるようになりますが、3G回線を利用したインターネットの接続のためにはいわゆるAPN(アクセスポイント)を設定しないといけません。

これについても、キャリアがオープンにしていない話題ですし、各所で紹介されているのでここでは省略します。

Googleの検索結果

その3:MMSの接続設定

APNの設定の中に、MMSを送受信するための設定も含まれています。SoftbankでMMSを送受信するために、これらの設定が正しくされている必要があります。

Googleの検索結果

その4:Mms.apkの上書き

SMSとMMSを司るソフトコンポーネントは Mms.apk というパッケージで、システム上の /system/app/Mms.apk というファイルです。

SoftbankのSMS,MMS通信ができない理由は、通信プロトコルの不整合や、AndroidOS自身に内在する不具合など複数の要因によって起こっています。これを根本解決するには、Androidのシステムライブラリを含めてSoftbank仕様として再コンパイル後、ファームアップデートとして顧客に配布するよりないのではないかと思います。が、ここでは、それを待っていたら、Softbankのアナウンス通り今年の後半まで指をくわえて待っていなければなりません。

で、必死になって Mms.apk を自分でコンパイルしました。

Softbank MMS問題の修正は、実は4月末までにとある方によってなされており、Android OSのソースを管理する Android Open Source Project にすでに反映されています。そこのソースコードを取得して必要なファイルを更新すればいい・・と思ったところそうは簡単ではないことがわかりました。

Softbank MMS問題の不具合は実はMms.apkの中ではなく、MMSの通信自体のライブラリが格納されている /system/framework/framework.jar という共有ライブラリの中にあったのです。ところが、このファイルを置換することは残念ながらできません。おそらく携帯デバイスやOSのビルドの種類ごとに異なる内容になっており、これを書き換えるとOSそのものが起動しなくなる恐れがあります。そこで、framework.jarには手を付けないで、Mms.apkだけでなんとか済まされないかと格闘。

苦肉の策は、framework.jar に含まれていたMMS関連のソースコードを引き抜いてきて、Mms.apkのソースコードとしてコンパイルしなおすというものです。

この結果、Android標準のメッセージアプリでは無事SMS/MMS/携帯メール の送受信が正しく行えるようになりました。

Softbankでの利用では、Mms.apkを更新後、まず最初に User-Agentの設定を忘れずに行ってください。

 

改善される点のまとめ

  • UserAgentが選択またはカスタム設定可能
  • SoftbankのMMSの送受信の種々の不具合の改善
    (メッセージの不着、着信しても本文空、画像添付時の不具合などが改善)
  • ENTERキーで送信した場合にメッセージが同じもの2通が送信されてしまう不具合
  • バイブレーションパターンの設定、LEDの設定がある(HTC DesireではLED動かず?)
  • 送信アドレスの入力テキストボックスでの検索と候補表示で電話番号だけでなくメールアドレスからも選択できるようになった。
  • 新たな設定項目(Eclairのソースコードに含まれていたものを含む)
    スレッドの背景色(有機ELのDesireの場合黒のほうが消費電力が少ない?)
    改行キーで送信するかしないかの設定
    フォントサイズの設定
Mms.apkjakeMod5以降での更新
  • アドレス帳のメールアドレスからSMS/MMS送信にジャンプできるように修正。
  • 既存のスレッドにない宛先にジャンプした時の不具合など修正。
Mms.apk.jakeMod6での更新
  • ファイル名としてふさわしくない文字列を含む添付ファイルを保存しようとするとできない。
  • 件名に日本語を含んだメッセージを「書きかけ」としていったん保存すると再度の編集時、件名が文字化けする。
Mms.apk.jakeMod7での更新
Mms.apk.jakeMod8の更新内容
  • ほかのアプリからEMAILアドレスが引き渡された時にアドレスが失われる問題を修正
    Intent.ACTION_SEND で Intent.EXTRA_EMAIL の参照を追加。
    ※元々Mms.apkはEメールアドレスを取り扱う想定が全くなかったのでこういうことに・・・
Mms.apk.jakeMod9の更新内容
  • mailto:******?subject=xxxx&body=xxxxx にただしく対処
Mms.apk.jakeMod10の更新内容
  • multipart/alternative の取り扱いミスで文字化けを修正
  • X01TのUser-Agentを修正
Mms.apk.jakeMod11の更新内容
  • cyanogenリポジトリからの修正分を(2010/6/30までの分)

制限事項:

  • この Mms.apk 差し替えで有効なのは Androidに標準の「メッ セージ」アプリを使用した場合だけです。アンドロイドマーケットで配布されている各種SMS/MMSアプリでは同様の問題は改善されません。
  • 受信中に表示を切り替えたりすると、異常終了するなどの不具合は時々見られます。(もともと内在する不具合か)

ダウンロードはこちら

Mms.apk.jakeMod11

  • 想定環境: Android OS 2.0以上 (HTC Desire ROM 1.21 MoDaCo Custom ROM r1 r2 r3 r3.1で動作確認済み)
  • Android 2.2 (Froyo)の場合はこちら

 

Mms.apk.jakeMod11 (897 kb)