目的に応じて適材適所で使うPHPライブラリ(11)
WINGSプロジェクト 片渕 彼富 [著] 山田 祥寛 [監修] 2010/10/01 14:00

サンプルファイル 12.43 KB
← 1 2 3 4 5 6 →

セッション管理クラスの作成

 PHPのセッション関数をそのまま書いていくとコードが煩雑になりがちです。

 PHPのセッション管理機能を包括するライブラリにHTTP_Session、HTTP_Session2というライブラリがあります。

 HTTP_Session2ライブラリはHTTP_Sessionライブラリの後継にあたるPHP5向けのライブラリで、session_* 系の関数へのオブジェクト指向的なインターフェイスを持ち、データベースをコンテナに利用(後述)したり有効期限やアイドル時間を設定できる機能を持っています。

 本サンプルではこのHTTP_Session2を利用してセッション管理クラスを作成します。

 セッション管理ライブラリHTTP_Session2の主なメソッドは以下のとおりです。

HTTP_Session2の主なメソッド
メソッド名意味
start()セッションを開始する
id()セッションIDの値を参照する
name(string $name)セッションIDの名前を設定する $name指定がない場合は「SessionID」がセッションID名となる
set( string $name, mixed $value )セッションに$name, $valueのペアで名前と値を設定する
setExpire( 秒数 )セッションの有効期間を設定する
setIdle( 秒数 )セッションのアイドル時間を設定する
setContainer( string $container, [array $container_options = null])セッションのデータをデータベースに保存する(後述)
useCookies( true / false )クッキーを使用する / 使用しない
useTransSID( true / false )session.use_trans_sidパラメータを使用する / 使用しない デフォルトが「true」
regenerateId( true / false )古いセッション情報を破棄して / 破棄せずに セッションIDを再生成する デフォルトが「false」ry

 HTTP_Session2ではセッションをDBに保存する機能があります。

 保存するDBの形式を「コンテナ」といい、String型の変数で指定します。さらにその際のDSN設定やテーブル名などを「コンテナオプション」として配列で指定します。

 コンテナの種類にはDB、MDBがあります。

 本記事ではこの機能は利用しませんので、詳しくはPEARの解説ページを参照してください。

 HTTP_Session2を使って、各画面から呼び出すセッションを管理するクラスをSessionの名前で作成します。

 具体的にはコンストラクタの部分でconfig.phpの読み込みとHTTP_Session2の初期設定、セッションの開始を行い、ログイン後にセッションにデータを置くメソッド、他HTTP_Session2のメソッドを利用してセッションの取得、セッションの破棄のメソッドを作成します。

リスト8 Session.class.php(抜粋)
/**
 * コンストラクタ
 */
function __construct(){
    // 設定ファイル読み込み
    include('config.php');
    //クッキーを使用しない
    HTTP_Session2::useCookies(false);
    // セッション開始
    HTTP_Session2::start();
}
/**
 * ログイン
 */
function login($user_id, $password){
    $pdo = new PDO(dbType.":host=".MYSQL_HOST."; dbname=".MYSQL_DATABASE, MYSQL_USER,   MYSQL_PASSWORD, 
                   array( PDO::MYSQL_ATTR_READ_DEFAULT_FILE => OPTION_CNF ));
    $stmt = $pdo->prepare("SELECT id, user_id, user_name, uid FROM user where user_id = ? AND password = ?");
    $stmt->execute(array($user_id, md5($password)));
    $rowCount = $stmt->rowCount();
    // userテーブルにデータが存在した場合はセッションに置く
    if($rowCount){
        $row = $stmt->fetch(PDO::FETCH_ASSOC);
        HTTP_Session2::set('user', $row);
    }
    return $rowCount;
}
/**
 * かんたんログイン
 */
function easyLogin($uid){
    # 端末IDをキーとしてloginメソッドと同様にユーザーデータを取得してセッションに置く
}

/**
 * セッション上のユーザー情報を返却
 */
function getSession(){
    return HTTP_Session2::get('user');
}

/**
 * ログインしているか?
 */
function isLogin()
{
    $_user = HTTP_Session2::get('user');
    $return = (isset($_user['id'])) ? true : false;
    return $return;
}

/**
 * セッション破棄
 */
function destroy(){
    HTTP_Session2::destroy();
}

 セッション内に「user」というキーでユーザーのデータを置いています。

 ユーザーデータを取得する際には「user」のキーでセッションからデータを取得します。


プロフィール
WINGSプロジェクト 片渕 彼富 カタフチ カノトミ

WINGSプロジェクトについて>
有限会社 WINGSプロジェクトが運営する、テクニカル執筆プロジェクト(代表 山田祥寛)。海外記事の翻訳から、主にWeb開発分野の書籍・
雑誌/Web記事の執筆、講演等を幅広く手がける。2008年8月時点での登録メンバは25名で、現在も一緒に執筆をできる有志を募集中。執筆に興味のある方は、どしどし応募頂きたい。著書多数


プロフィール
山田 祥寛 ヤマダ ヨシヒロ

静岡県榛原町生まれ。一橋大学経済学部卒業後、NECにてシステム企画業務に携わるが、2003年4月に念願かなってフリーライターに転身。Microsoft MVP for ASP/ASP.NET。執筆コミュニティ「WINGSプロジェクト」代表。
主な著書に「入門シリーズ(サーバサイドAjax/XMLDB/PEAR/Smarty)」「独習シリーズ(ASP.NET/PHP)」「10日でおぼえる入門教室シリーズ(ASP.NET/PHP/Jakarta/JSP&サーブレット/XML)」「Pocket詳解辞典シリーズ(ASP.NET/PHP/Perl&CGI)」「今日からつかえるシリーズ(PHP/JSP&サーブレット/XML/ASP)」「書き込み式 SQLのドリル」他、著書多数


注目の求人情報
システムエンジニア/オンラインゲーム会社
◇こんな会社です: ・オンラインゲームの企画開発、運営を主な事業としています。自社開発コンテンツ...
システムエンジニア/人材紹介WEBポータル
・UNIX、Linuxベースの開発経験 ・PHP、JAVA、PostgreSQL、MySQLなどの経験2年以上 ・オブジェクト指...
コンサルタント/コンサルティング企業
エクセレントカンパニーを対象とし、全体最適の視点を持ったITのグランド・デザインから構築・運用ま...

(最新日付順)
名前(ゲストの方もコメントをどうぞ):*
アイコン:
なし

内容(テキストのみ1200文字まで):*

投稿規定に同意して

スポンサーサイト

この記事のトラックバックURL: