携帯電話からのアクセスの場合にリダイレクトする
もちろん、コントローラでrequest.mobile?を使用することもできます。携帯電話用に独自の作り込みが必要になる場合には、携帯電話とPCとを別のコントローラで処理するのがいいでしょう。
次は、mobileコントローラを作成して、携帯電話からpcコントローラにアクセスがあった場合には、mobileコントローラにリダイレクトするようにしてみましょう。
% ./script/generate controller mobile index |
app/controllers/pc_controller.rbにフィルタを追加します。redirect_if_mobileを用意し、before_filterで指定します。
class PcController < ApplicationController |
Webブラウザを開き、/pcにアクセスしてみましょう。通常の(PCの)User-AgentでアクセスするとPC用のビュー(Railsによって生成されたデフォルトのページ。Pc#indexというタイトル)が表示されます。
一方、携帯電話のUser-Agentでアクセスすると、/pcから/mobileにリダイレクトされ、携帯電話用のビュー(Mobile#indexというタイトル)が表示されます。
さらに、キャリアの判別が必要な場合もあると思います。このようなときは、
case request.mobile |
とします。
また、 特定のキャリアかどうかを判別する場合には、
if request.mobile.docomo? |
と書くこともできます(ほかにau?、softbank?、willcom?、emobile?が使用できます)。
さらに、テンプレートの中で分岐したい場合には、
<% if request.mobile.docomo? %> |
とすることもできます。
携帯電話ビューへの自動振り分け
先ほどは、コントローラをPC用と携帯電話用の2種類を用意して、切り替えていました。これは、PCと携帯電話で画面遷移が大きく異なるなど、コントローラを別々に用意する必要がある場合には有効です。
しかし、PCと携帯でビューだけが異なるような場合には少々大げさです。このようなときには、ビューだけを簡単に切り替えることができるビューの自動振り分けを使ってみましょう。
index.html.erbに対して、同じディレクトリにindex_mobile.html.erbを配置すると、携帯電話からのアクセスには自動的にindex_mobile.html.erbが使われるようになります。
1つのHybridコントローラで両方のアクセスに対応してみましょう。まず、コントローラを作成します。
% ./script/generate controller hybrid index
|
次に、app/views/hybrid/index_mobile.html.erbを作ってみましょう。例えば、
<h1>Mobile view</h1> |
としてみます。これだけで携帯電話からのアクセスの場合だけ、こちらが表示されるようになります。PCの場合はそのまま、つまりRailsが生成したindex.html.erbが表示されるはずです。
それぞれのWebブラウザで/hybridを表示して確認してみてください。
このように、ページ遷移などがPC用と大きく変わらない場合には、テンプレートを別に用意するだけで表示を切り替えることができます。
さらに、携帯電話のキャリアごとにテンプレートを切り替えることもできます。app/views/hybrid/index_mobile_docomo.html.erbを作成してみます。例えば、
<h1>DoCoMo view</h1> |
とします。これで、ドコモ携帯からのアクセスの場合のみ、このテンプレートが利用されるようになります。ドコモ以外の携帯電話では、先ほどの携帯電話用テンプレート、app/views/hybrid/index_mobile.html.erbが使用されます。
auやソフトバンクなどの携帯電話でも同様の手順となります。
まとめると、indexに対するテンプレートは以下の順番で検索され、最初に見つかったものが使用されることになります。
- PCの場合:index.html.erb
- ドコモ携帯電話の場合:index_mobile_docomo.html.erb → index_mobile.html.erb → index.html.erb
- au携帯電話の場合:index_mobile_au.html.erb → index_mobile.html.erb → index.html.erb
- ソフトバンク携帯電話の場合:index_mobile_softbank.html.erb → index_mobile.html.erb → index.html.erb
- ウィルコム携帯電話の場合:index_mobile_willcom.html.erb → index_mobile.html.erb → index.html.erb
2/3 |
Index | |
jpmobileはじめの一歩 | |
Page1 jpmobileをRailsに組み込んでみる アクセス元が携帯電話かPCかを判定する |
|
Page2 携帯電話からのアクセスの場合にリダイレクトする 携帯電話ビューへの自動振り分け |
|
Page3 ディスプレイ情報の取得 まとめ |
jpmobileとRailsで楽しい携帯Web開発 |
Ruby/Rails関連記事 |
プログラミングは人生だ まつもと ゆきひろのコーディング天国 ときにプログラミングはスポーツであり、ときにプログラミングは創造である。楽しいプログラミングは人生をより実りあるものにしてくれる |
|
生産性を向上させるRuby向け統合開発環境カタログ Ruby on Rails 2.0も強力サポート 生産性が高いと評判のプログラミング言語「Ruby」。統合開発環境を整えることで、さらに効率的なプログラミングが可能になる |
|
かんたんAjax開発をするためのRailsの基礎知識 Ruby on RailsのRJSでかんたんAjax開発(前編) 実はAjaxアプリケーション開発はあなたが思うよりも簡単です。まずはRuby on Railsの基礎知識から学びましょう |
|
Praggerとnetpbmで作る画像→AA変換ツール Rubyを使って何か面白いものを作ってみよう! 一般的な画像をアスキーアートに変換するツールを作ってみる。さらに出力にバリエーションを持たせてみよう |
|
コードリーディングを始めよう Railsコードリーディング〜scaffoldのその先へ〜(1) 優れたプログラマはコードを書くのと同じくらい、読みこなす。優れたコードを読むことで自身のスキルも上達するのだ |
|
- プログラムの実行はどのようにして行われるのか、Linuxカーネルのコードから探る (2017/7/20)
C言語の「Hello World!」プログラムで使われる、「printf()」「main()」関数の中身を、デバッガによる解析と逆アセンブル、ソースコード読解などのさまざまな側面から探る連載。最終回は、Linuxカーネルの中では、プログラムの起動時にはどのような処理が行われているのかを探る - エンジニアならC言語プログラムの終わりに呼び出されるexit()の中身分かってますよね? (2017/7/13)
C言語の「Hello World!」プログラムで使われる、「printf()」「main()」関数の中身を、デバッガによる解析と逆アセンブル、ソースコード読解などのさまざまな側面から探る連載。今回は、プログラムの終わりに呼び出されるexit()の中身を探る - VBAにおけるFileDialog操作の基本&ドライブの空き容量、ファイルのサイズやタイムスタンプの取得方法 (2017/7/10)
指定したドライブの空き容量、ファイルのタイムスタンプや属性を取得する方法、FileDialog/エクスプローラー操作の基本を紹介します - さらば残業! 面倒くさいエクセル業務を楽にする「Excel VBA」とは (2017/7/6)
日頃発生する“面倒くさい業務”。簡単なプログラミングで効率化できる可能性がある。本稿では、業務で使うことが多い「Microsoft Excel」で使えるVBAを紹介する。※ショートカットキー、アクセスキーの解説あり
|
|