快速入門(mén):PHP Session用法
PHP經(jīng)過(guò)長(zhǎng)時(shí)間的發(fā)展,很多用戶都很了解PHP了,這里我發(fā)表一下個(gè)人理解,和大家討論討論P(yáng)HP Session用法。對(duì)于虛擬主機(jī)來(lái)說(shuō),如果所有用戶的Session都保存在系統(tǒng)臨時(shí)文件夾里,將給維護(hù)造成困難,而且降低了安全性,我們可以手動(dòng)設(shè)置 Session 文件的保存路徑,session_save_path() 就提供了這樣一個(gè)功能。我們可以將 Session 存放目錄指向一個(gè)不能通過(guò) Web 方式訪問(wèn)的文件夾,當(dāng)然,該文件夾必須具備可讀寫(xiě)屬性。
PHP Session用法:
- <?php
- // 設(shè)置一個(gè)存放目錄
- $savePath = "./session_save_dir/";
- // 保存一天
- $lifeTime = 24 * 3600;
- session_save_path($savePath);
- session_set_cookie_params($lifeTime);
- session_start();
- $_SESSION["admin"] = true;
- ?>
同 session_set_cookie_params(); 函數(shù)一樣,session_save_path() 函數(shù)也必須在 session_start() 函數(shù)調(diào)用之前調(diào)用。我們還可以將數(shù)組,對(duì)象存儲(chǔ)在 Session 中。操作數(shù)組和操作一般變量沒(méi)有什么區(qū)別,而保存對(duì)象的話,PHP 會(huì)自動(dòng)對(duì)對(duì)象進(jìn)行序列化(也叫串行化),然后保存于 Session 中。下面例子說(shuō)明了這一點(diǎn):
person.php
- <?php
- class person
- {
- var $age;
- function output() {
- echo $this->age;
- }
- function setAge($age) {
- $this->age = $age;
- }
- }
- ?>
- setage.php
- <?php
- session_start();
- require_once "person.php";
- $person = new person();
- $person->setAge(21);
- $_SESSION['person'] = $person;
- echo "<a href='output'>check here to output age</a>";
- ?>
- output.php
- <?
- // 設(shè)置回調(diào)函數(shù),確保重新構(gòu)建對(duì)象。
- ini_set('unserialize_callback_func', 'mycallback');
- function mycallback($classname) {
- include_once $classname . ".php";
- }
- session_start();
- $person = $_SESSION["person"];
- // 輸出 21
- $person->output();
- ?>
#T#當(dāng)我們執(zhí)行 setage.php 文件的時(shí)候,調(diào)用了 setage() 方法,設(shè)置了年齡為 21,并將該狀態(tài)序列化后保存在 Session 中(PHP 將自動(dòng)完成這一轉(zhuǎn)換),當(dāng)轉(zhuǎn)到 output.php 后,要輸出這個(gè)值,就必須反序列化剛才保存的對(duì)象,又因?yàn)樵诮庑蛄谢臅r(shí)候需要實(shí)例化一個(gè)未定義類(lèi),所以我們定義了以后回調(diào)函數(shù),自動(dòng)包含 person.php 這個(gè)類(lèi)文件,因此對(duì)象被重構(gòu),并取得當(dāng)前 age 的值為 21,然后調(diào)用 output() 方法輸出該值。另外,我們還可以使用 session_set_save_handler 函數(shù)來(lái)自定義 PHP Session用法。