[PHP] HTTP 連線的資料共用

我相信有許多 Web 應用程式開發者與我類似,常常想辦法預存一些經常存取、變動頻率不高的資料,提昇程式效能。
透過這類的資料預存,可以降低資料庫存取頻率,並減少 server 的 file I/O 次數。

在 .Net 與 JAVA 的領域,程式語言都提供了相關的物件/變數,讓 Web 應用程式儲存資料,而該應用程式的所有連線使用者皆可以存取。
.Net 用的是 System.Web.Caching.Cache;JAVA Servlet 是 javax.servlet.ServletContext,而 JSP 的 Application 物件便是其實作。
但在常見的環境(eg. Apache HTTPD w/MPM prefork + mod_php),也沒有額外的模組(eg. APCmemcache),PHP 難以提供這種物件/變數讓人使用,開發者只能硬幹。 :p

因為 COOKIE 的 size 有限,在 PHP 大概只能用 SESSION 硬幹。
我是這樣做的…

存入/更新

function writeAppCache( $app_name , $data ) {
    // 紀錄原本的 session ID
    $orig_session_id = session_id();

    // 如果已有 session 存在
    if ( !empty($orig_session_id) ) {

        // 存放原本的 session 資料
        session_write_close();

        // 切換到自己定義的 application session,存放/更新資料
        session_id($app_name);
        $_SESSION = $data;
        session_write_close();

        // 切換回原本的 session
        session_id($orig_session_id);
        session_start();
    }
}

讀取

function readAppCache( $app_name ) {
    $data = null;
    // 紀錄原本的 session ID

    $orig_session_id = session_id();
    // 如果已有 session 存在
    if ( !empty($orig_session_id) ) {

        // 存放原本的 session 資料
        session_write_close();

        // 切換到自己定義的 application session,讀取資料
        session_id($app_name);
        $data = $_SESSION;
        session_write_close();

        // 切換回原本的 session
        session_id($orig_session_id);
        session_start();
    }
    return $data;
}

因為所有程式都能存取 session 內的資料,不建議在 session 內儲存私密/機密資料。
若要避免資料不小心被同一台 server 的其他程式,可以加上 session_name() 作區隔。