アンケートご協力のお願いgihyo.jpでは,2010年度に向けて豪華プレゼントが当たる読者属性アンケートを実施しております。ご協力ください。

gihyo.jp » DEVELOPER STAGE » 特集 » いますぐ使えるOpenID » 第4回 Railsで作るOpenID対応アプリケーション実践(前編)

いますぐ使えるOpenID

第4回 Railsで作るOpenID対応アプリケーション実践(前編)

はじめに

今回はいよいよ,アプリケーションを作りながら,OpenIDの実践的な使い方を解説します。サンプルとして作成するアプリケーションは,ミニブログと呼ばれるつぶやきブログです。いわゆるTwitterクローンです。利用者はミニブログにログインして,一言つぶやきます。ブログの一種ですので,当然ユーザ認証が必要になります。普通はパスワードを用いた認証が一般的ですが,今回はOpenIDを用いてユーザを認証するようにアプリケーションを作成していきます。

さて,認証と簡単に言いましたが,認証に必要となる機能をもう少し具体的に列挙してみましょう。

ユーザ登録
サービスを利用するために必要な情報(IDやメールアドレスなど)を利用者に入力してもらい,データベースへ登録する。
ログイン(認証)
利用者が入力した認証情報(パスワードなど)を元に利用者を認証し,ログインの可否を判定する。ログインに成功した利用者には,認証済みであることを識別するための識別子(セッションCookie)を発行する。
セッション管理
利用者から送信されるセッションCookieを元に,その利用者が認証済みであることを確認する。一定時間アクセスがない利用者はセッションを無効にする。
アクセス制御(認可)
利用者がアクセス先のリソースへの権限を持っているかどうかを判定する。
ログアウト
セッションを破棄し利用者の認証状態を解除する。
アカウント管理
利用者が登録した情報を変更できるようにする。パスワードの変更やパスワード紛失時の再発行も担当する。

図1 認証に必要となる機能

図1 認証に必要となる機能

いかがでしょうか。想像したよりも認証に必要となる機能は多岐に渡ります。OpenIDを使うことで,これらの機能がどのように変わるのか(または変わらないのか)を見ていきましょう。

なお,常にすべての機能が必要という訳ではなく,アプリケーションによって必要な機能は変わります。例えば,ブログのコメント欄に認証機能を組み込むのあれば,コメント投稿時だけ利用者を確認できればよいため,ユーザ登録やセッション管理は不要になります。何のために利用者を認証するのかは,事前にしっかりと考えておくことが大切でしょう。

RailsのOpenIDプラグイン(OpenID Authentication)

RailsにはOpenIDを用いてユーザを認証するためのOpenID Authenticationというプラグインが存在します。このプラグインはこの連載で紹介したruby-openidライブラリのラッパーです。OpenID Authenticationプラグインを使うことで,ruby-openidライブラリをそのまま使うよりも簡単に,OpenIDをRailsアプリケーションに組み込むことができます。RailsのOpenID Authenticationプラグインは,長い間OpenID 2.0に対応していませんでした。しかし,Josh Peekが提案したパッチが2008年3月27日にプラグインに取り込まれ,今では標準でOpenID 2.0に対応しています。

Railsにはユーザ認証のためのプラグインがいくつか用意されています。Rails 1.x系の頃にはacts_as_authenticatedプラグインがよく使われていましたが,Rails 2.xではRestful Authenticationプラグインが使われているようです。OpenID Authenticationプラグインはこれらの従来の認証プラグインと競合するものではありません。むしろ,これらのプラグインと併用して使うものといえるでしょう。それぞれのプラグインの機能を,表1で比較します。

表1 認証プラグインの機能比較

 Restful AuthenticationOpenID Authentication
ユーザ登録×
ログイン(認証)○(パスワード)○(OpenID)
セッション管理×
アクセス制御×
ログアウト×
アカウント管理××

とはいえ,まずはOpenID Authenticationプラグインを単体で利用します。Restful AuthenticationプラグインとOpenID Authenticationプラグインの連携は次回挑戦します。

著者プロフィール

松岡浩平(まつおかこうへい)

NTTコムウェア株式会社にて,オープンソースを活用した認証システムの開発を担当しています。ここ2年は,情報セキュリティ大学院大学に通学しながら,OpenIDを使った認証システムについて研究していました。

コメント

  • 無題

    controller/users_controller.rb

    def create
    @user = User.new(params[:user])
    # identity_url 属性にセッションで保存した値を代入
    @user.identity_url = session[:identity_url]
    if @user.save
    # ユーザ登録に成功したら home 画面へ移動
    redirect_to(user_home_path)
    else
    render :action => "new" }
    end
    end

    renderの部分が変じゃないですか?

    Commented : #1  typo? (2008/12/31, 22:06)

コメントの記入

パスサポ

多数の情報処理技術者試験対策書籍の発行実績を誇る技術評論社がお届けする,資格試験合格サイト「めざせ! 情報処理試験 パスサポ」が開設されました。

ピックアップ

サクセスストーリーに続く,快適サーバー運用管理のヒント!

データの増大,煩雑な管理,システムダウン,セキュリティなど,迫りくる課題からシステム管理者の負担を軽くするポイントを解説します。

gihyo.jp インフラエンジニア情報局

ネットワークやITにかかわるあらゆる業種で必要とされるインフラエンジニアに向けた技術情報や心構え,その魅力について多角的に紹介。

テストエンジニア ステーション

いま,ITに関わるあらゆる開発業務で注目されつつあるテスト系エンジニアをターゲットにしたコンテンツサイトを展開します。

一行クイックアンケート

gihyo.jpで取り上げてほしいネタは?

※検索はページ右上の検索ボックスをご利用ください。

その他の連載

キーパーソンが見るWeb業界

本連載はWeb Site Expert/gihyo.jpとの連動企画です。阿部淳也, 長谷川敦士, 森田雄のお三方による,Web業界をテーマにした座談会です。

きたみりゅうじの聞かせて珍プレー

ソフトウェア開発の現場で体験したトホホな失敗,思わずうなる珍プレーをきたみりゅうじ氏が四コママンガで紹介。みなさんからの投稿もお待ちしてます!

ActionScript 3.0で始めるオブジェクト指向スクリプティング

野中文雄氏が,簡単なスクリプトは書いたことがあるという初級者を対象に,ActionScript 3.0の基本からクラス定義までを解説します。

まだ間に合う「ITパスポート」受験対策 原山先生の短期合格塾

この連載では,4月18日のITパスポート試験の受験に向けて,短い期間で効率良く受験対策を行う方法や,確実に得点するための裏ワザなどを伝授していきます。

Ubuntu Weekly Recipe

Ubuntuの強力なデスクトップ機能を活用するための,いろいろなレシピをお届けします。

C/C++プログラマのためのDTrace入門

よくカーネルのチューニングや解析で活用されるDTraceですが,実はユーザプログラムの開発においても非常に有用です。連載ではC/C++プログラマやテストに関わる方向けにDTraceの使い方を解説します。

Blogopolisから学ぶ計算幾何

計算幾何学は,図形に関するアルゴリズムを研究するコンピュータサイエンスの一分野です。本連載では,ビジュアルブログ検索エンジン「Blogopolis」で採用されている計算幾何のアプローチを例に取り上げながら,計算幾何の初歩を実践的に学習します。

検索エンジンはいかにして動くのか?

本連載では, 今や誰もが利用している検索エンジンの中身を,全体の仕組みやデータ構造,アルゴリズムから分散インデックスまで,最近の研究事例も交えて紹介します。

連載一覧

gihyo.jp

  • DEVELOPER STAGE
  • ADMINISTRATOR STAGE
  • WEB+DESIGN STAGE
  • LIFESTYLE STAGE
  • SCIENCE STAGE
  • NEWS & REPORT

書籍案内

  • 新刊書籍
  • 書籍ジャンル一覧
  • 書籍シリーズ一覧
  • 新刊ピックアップ
  • ロングセラー
  • 電脳会議

定期刊行物一覧

  • Software Design
  • WEB+DB PRESS
  • Web Site Expert
  • 組込みプレス