快速入門:PHP Session用法
PHP經(jīng)過長時(shí)間的發(fā)展,很多用戶都很了解PHP了,這里我發(fā)表一下個(gè)人理解,和大家討論討論P(yáng)HP Session用法。對于虛擬主機(jī)來說,如果所有用戶的Session都保存在系統(tǒng)臨時(shí)文件夾里,將給維護(hù)造成困難,而且降低了安全性,我們可以手動設(shè)置 Session 文件的保存路徑,session_save_path() 就提供了這樣一個(gè)功能。我們可以將 Session 存放目錄指向一個(gè)不能通過 Web 方式訪問的文件夾,當(dāng)然,該文件夾必須具備可讀寫屬性。
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ù)組,對象存儲在 Session 中。操作數(shù)組和操作一般變量沒有什么區(qū)別,而保存對象的話,PHP 會自動對對象進(jìn)行序列化(也叫串行化),然后保存于 Session 中。下面例子說明了這一點(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)建對象。
- 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 將自動完成這一轉(zhuǎn)換),當(dāng)轉(zhuǎn)到 output.php 后,要輸出這個(gè)值,就必須反序列化剛才保存的對象,又因?yàn)樵诮庑蛄谢臅r(shí)候需要實(shí)例化一個(gè)未定義類,所以我們定義了以后回調(diào)函數(shù),自動包含 person.php 這個(gè)類文件,因此對象被重構(gòu),并取得當(dāng)前 age 的值為 21,然后調(diào)用 output() 方法輸出該值。另外,我們還可以使用 session_set_save_handler 函數(shù)來自定義 PHP Session用法。