以前搞過一段時間的asp,覺得application這個對象很爽。??梢院苋菀椎膶懸粋€聊天室。。。后來逐漸轉到php,就一直為這事郁悶。。因為php里面沒有對應的東西。數據只能往數據庫或者文件里面寫才能實現共享。 今天在公司做聊天室的時候,靈機一動,居然讓我發現了一神奇的方法~~哈哈:
PHP里面的$_SESSION變量可以實現類似Application的功能,但重點在它不能跨瀏覽器進程,或者說是跨用戶。。只能是單個用戶操作不同頁面時候的變量傳遞,是一種cookie的替代方案。
眾所周知,php里,調用session_start()之后,客戶瀏覽器會收到一個大概名叫PHPSESSID的cookie,這個叫session_id。不同頁面的參數共享就是靠這個變量實現的。
有時,由于客戶端瀏覽器或者其他什么神奇的原因,導致無法正常發送 PHPSESSID的時候,我們可以手動發送,然后在php里面的session_start();之前,調用session_id("sessionid在這里");手工指定session_id ,這樣,就可以讓session工作正常。(比如瀏覽器不支持cookie,或用flash上傳文件的時候)
好了,關鍵的東西來了。如果我們讓每個用戶的session_id都一樣會怎么樣? 哈哈。ASP的Application功能便呼之欲出~~~
實現方法非常簡單: 在每個php頁面的前面都寫上下面的代碼: session_id("xxxx"); session_start(); 然后,你就可以像用Application對象那樣來使用$_SESSION了。?!伞?/BLOCKQUOTE>
PS:ASP的Application對象是存儲在內存里面的,而PHP的SESSION一般默認是用文件來存的。不過也可以設置php.ini讓php用mysql數據庫存,甚至用memcached來存~~具體方法就不詳述了。。 chy提到session本來的作用是保存用戶的登錄信息等,是非常有用的。我這樣一弄,session就失去了它原有的功能。所以我搞了一個函數,可以實現全局session和局部session共存?;ゲ桓蓴_。
/*
用法:
application('key','value'); //設置 key=value
$value = application('key'); //獲取 key的值
*/
function application()
{
$args = func_get_args(); //獲取輸入參數
if (count($args) >2 || count($args) < 1) return;
$ssid = session_id(); //保存當前session_id
session_write_close(); //結束當前session
ob_start(); //禁止全局session發送header
session_id("xxx"); //注冊全局session_id
session_start(); //開啟全局session
$key = $args[0];
if (count($args) == 2) //如果有第二個參數,那么表示寫入全局session
{
$re = ($_SESSION[$key] = $args[1]);
}
else // 如果只有一個參數,那么返回該參數對應的value
{
$re = $_SESSION[$key];
}
session_write_close(); //結束全局session
session_id($ssid); //重新注冊上面被中斷的非全局session
session_start(); //重新開啟
ob_end_clean(); //拋棄剛剛由于session_start產生的一些header輸出
return $re;
}
當然,這樣操作的成本有點高。。不過在實際使用中,基本不會遇到使用全局session和局部session的頻率都很高的情況。所以可以按需求封裝局部session或者是全局session。 上面那個函數封裝的是全局session,稍微修改就可以實現局部session。
該文章在 2012/6/7 1:56:51 編輯過