モバイルサイトを3キャリアでほぼ共通化して作りたい

May 30, 2008

フルブラウザ搭載機種が増えてきたとはいえ、実際に使うにはそれなりに定額サービスを利用しなければいけないし、操作性などを考えるとまだまだモバイルサイトを作る需要はある。未だに iモード向けコンテンツ (C-HTML) で作るのが一番簡単に共通化できるようだが、3G機種に焦点をあてて DoCoMo、au、SoftBank の最近の動向(2008年 5月 現在)を探ってみた。
なお、PC サイトのモバイルサイトを作るための情報収集のため、絵文字の利用については考慮しない。

各キャリアのコンテンツ制作者向けサイト

DoCoMo

開発者向け情報 | サービス・機能 | NTTドコモ

au

KDDI au: EZfactory

SoftBank

文字エンコーディング

SoftBank の機種を考慮すると、Shift_JIS での統一だけでは辛いようだ。
ネット上情報を探し回った結果文字エンコーディングは UTF-8 にほとんど対応しているものの Shift_JIS にしておき、そして CGI で受け取ったデータは、Shift_JIS → UTF-8 の順で判別するのがマシに思えた。

HTTP ヘッダ

Content-Type の出力

application/xhtml+xml; charset=Shift_JIS

ユーザエージェント

DoCoMo

「DoCoMo」で始まる ( 開発者向け情報 | サービス・機能 | NTTドコモ )

au

KDDI」で始まる ( 404 Not Found )

SoftBank

SoftBank」もしくは「Vodafone」もしくは「MOT」で始まる ( )

XHTML

DoCoMo
1
2
<?xml version="1.0" encoding="Shift_JIS"?>
<!DOCTYPE html PUBLIC "-//i-mode group (ja)//DTD XHTML i-XHTML(Locale/Ver.=ja/1.0) 1.0//EN" "i-xhtml\_4ja\_10.dtd">
au
1
2
<?xml version="1.0" encoding="Shift_JIS"?>
<!DOCTYPE html PUBLIC "-//OPENWAVE//DTD XHTML 1.0//EN" "http://www.openwave.com/DTD/xhtml-basic.dtd">
SoftBank
1
2
<?xml version="1.0" encoding="Shift_JIS"?>
<!DOCTYPE html PUBLIC "-//J-PHONE//DTD XHTML Basic 1.0 Plus//EN" "xhtml-basic10-plus.dtd">

画像フォーマット

対応は下記のとおりなので JPEG に統一がベター。ただアイコンようなを使うとすればむしろ GIF, PNG で分けたほうがいいかもしれない。ページ全体のサイズ制限にも注意が必要だろう。

DoCoMo

GIF, JPEG ( 開発者向け情報 | サービス・機能 | NTTドコモ )

au

GIF, JPEG, PNG ( 404 Not Found )

SoftBank

JPEG, PNG, GIF(一部古い機種で表示できない) ( ページが見つかりません )

上記をユーザーエージェントでスイッチして出力する CGI サンプル

CGI HTML

tilfin freelance software engineer