SoftbankでSIMフリーHTC Desireと最近のAndroid HTC Sense系 ROM(含備忘録)

海外で購入したHTC DesireにいろんなROMを焼いてしばらくこの話題から遠ざかっていました。気がつくとSoftbankからたくさんのAndroid端末が発売されており、その間に andglobal.softbank.ne.jp なる新しいAPNも設定されていました。

Softbankでの契約内容と使用可能なAPNの組み合わせについて 2ch でまとめられていたものを備忘録としてここにコピーしておきます。

 

◆パケットし放題S(3G) 

mailwebservice.softbank.ne.jp → ウェブ 

のみの接続であれば上限4,410円で定額 

open.softbank.ne.jp → PCダイレクト 

smile.world → PCダイレクト 

は上限が9,800円。 

andglobal.softbank.ne.jp → スマートフォン通信 

は青天井(未確認) 

 

◆パケットし放題フラット(iPhone、3G) 

ウェブ PCダイレクト分のみ定額になる。黒simフラット契約、銀simガラケー共に 

open.softbank.ne.jp → PCダイレクト 

smile.world → PCダイレクト 

mailwebservice.softbank.ne.jp → ウェブは定額範囲だったが、 

andglobal.softbank.ne.jp → スマートフォン通信 

に設定すると定額外で別枠だった。パケ死する恐れあり。 

Desireだとフラット契約を適用できたが、DHDでパケットし放題フラットを適用できなかったのも、 

APNとプランの設定で範囲で、初期DHD内でのAPNがandglobalな為、定額外扱いだからだと思われる。 

 

◆パケットし放題S forスマートフォン 

◆パケットし放題MAX forスマートフォン(受付終了) 

現時点(2011/5/10)では、銀Simでも緑Simでも 

mailwebservice.softbank.ne.jp → ウェブ(ガラケー扱い) 

open.softbank.ne.jp → PCダイレクト 

andglobal.softbank.ne.jp → スマートフォン通信 

smile.world → PCダイレクト 

のどれも定額内。 

(緑sim用の機種ならandglobal、銀sim用の機種Xシリーズならopenに接続されるが、契約はどちらでも同じ。) 

 

◆パケットし放題フラット forスマートフォン(2011/05/01より) 

・SoftBankスマートフォン(Xシリーズの場合、最新の販売履歴がXシリーズであること)のみ、お申し込みいただけます。 

・国内でご利用のS!メール[MMS]送信・読出料、ウェブ・PCサイトブラウザ(PCメールを含む)・PCサイトダイレクト(Xシリーズ専用)通信料が定額の対象となります。 

スマホ用プランでパケットし放題MAX/Sと同様となので 

mailwebservice.softbank.ne.jp → ウェブ(ガラケー扱い) 

open.softbank.ne.jp → PCダイレクト 

andglobal.softbank.ne.jp → スマートフォン通信 

smile.world → PCダイレクト 

のどれも定額内と思われる。 

 

あと、私自身がひっかかった非常に重要な落とし穴として最近のHTC DesireのROMにははじめからSoftbankのAPN設定が含まれていますが、中に andglobal な設定しかないROMがあり、こういったROMを焼いてAndroidが起動、アカウントでサインインすると、以前のバックアップとアプリのダウンロードをすべくネットに自動的に接続に行きます。この間有無を言わさず通信が始まりますからどこのAPNに接続しているか未確認の状態では非常に危険です。

/system/etc/apns-conf.xmlの内容を十分確認するか、SIMを抜いた状態で初期設定を行うなど気を使う必要があります。

皆様もご注意ください。

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)