推薦學(xué)習(xí)php sesson的朋友必看PHP會(huì)話(Session)使用入門第1/2頁
更新時(shí)間:2008年08月12日 12:31:11 作者:
對(duì)比起 Cookie,Session 是存儲(chǔ)在服務(wù)器端的會(huì)話,相對(duì)安全,并且不像 Cookie 那樣有存儲(chǔ)長(zhǎng)度限制,本文簡(jiǎn)單介紹 Session 的使用。
由于 Session 是以文本文件形式存儲(chǔ)在服務(wù)器端的,所以不怕客戶端修改 Session 內(nèi)容。實(shí)際上在服務(wù)器端的 Session 文件,PHP 自動(dòng)修改 Session 文件的權(quán)限,只保留了系統(tǒng)讀和寫權(quán)限,而且不能通過 ftp 修改,所以安全得多。
對(duì)于 Cookie 來說,假設(shè)我們要驗(yàn)證用戶是否登陸,就必須在 Cookie 中保存用戶名和密碼(可能是 md5 加密后字符串),并在每次請(qǐng)求頁面的時(shí)候進(jìn)行驗(yàn)證。如果用戶名和密碼存儲(chǔ)在數(shù)據(jù)庫,每次都要執(zhí)行一次數(shù)據(jù)庫查詢,給數(shù)據(jù)庫造成多余的負(fù)擔(dān)。因?yàn)槲覀儾⒉荒苤蛔鲆淮悟?yàn)證。為什么呢?因?yàn)榭蛻舳?nbsp;Cookie 中的信息是有可能被修改的。假如你存儲(chǔ) $admin 變量來表示用戶是否登陸,$admin 為 true 的時(shí)候表示登陸,為 false 的時(shí)候表示未登錄,在第一次通過驗(yàn)證后將 $admin 等于 true 存儲(chǔ)在 Cookie,下次就不用驗(yàn)證了,這樣對(duì)么?錯(cuò)了,假如有人偽造一個(gè)值為 true 的 $admin 變量那不是就立即取的了管理權(quán)限么?非常的不安全。
而 Session 就不同了,Session 是存儲(chǔ)在服務(wù)器端的,遠(yuǎn)程用戶沒辦法修改 Session 文件的內(nèi)容,因此我們可以單純存儲(chǔ)一個(gè) $admin 變量來判斷是否登陸,首次驗(yàn)證通過后設(shè)置 $admin 值為 true,以后判斷該值是否為 true,假如不是,轉(zhuǎn)入登陸界面,這樣就可以減少很多數(shù)據(jù)庫操作了。而且可以減少每次為了驗(yàn)證 Cookie 而傳遞密碼的不安全性了(Session 驗(yàn)證只需要傳遞一次,假如你沒有使用 SSL 安全協(xié)議的話)。即使密碼進(jìn)行了 md5 加密,也是很容易被截獲的。
當(dāng)然使用 Session 還有很多優(yōu)點(diǎn),比如控制容易,可以按照用戶自定義存儲(chǔ)等(存儲(chǔ)于數(shù)據(jù)庫)。我這里就不多說了。
Session 在 php.ini 是否需要設(shè)置呢?一般不需要的,因?yàn)椴⒉皇敲總€(gè)人都有修改 php.ini 的權(quán)限,默認(rèn) Session 的存放路徑是服務(wù)器的系統(tǒng)臨時(shí)文件夾,我們可以自定義存放在自己的文件夾里,這個(gè)稍后我會(huì)介紹。
開始介紹如何創(chuàng)建 Session。非常簡(jiǎn)單,真的。
啟動(dòng) Session 會(huì)話,并創(chuàng)建一個(gè) $admin 變量:
<?php
// 啟動(dòng) Session
session_start();
// 聲明一個(gè)名為 admin 的變量,并賦空值。
$_SESSION["admin"] = null;
?>
如果你使用了 Seesion,或者該 PHP 文件要調(diào)用 Session 變量,那么就必須在調(diào)用 Session 之前啟動(dòng)它,使用 session_start() 函數(shù)。其它都不需要你設(shè)置了,PHP 自動(dòng)完成 Session 文件的創(chuàng)建。
執(zhí)行完這個(gè)程序后,我們可以到系統(tǒng)臨時(shí)文件夾找到這個(gè) Session 文件,一般文件名形如:sess_4c83638b3b0dbf65583181c2f89168ec,后面是 32 位編碼后的隨機(jī)字符串。用編輯器打開它,看一下它的內(nèi)容:
admin|N; 一般該內(nèi)容是這樣的結(jié)構(gòu):
變量名|類型:長(zhǎng)度:值; 并用分號(hào)隔開每個(gè)變量。有些是可以省略的,比如長(zhǎng)度和類型。
我們來看一下驗(yàn)證程序,假設(shè)數(shù)據(jù)庫存儲(chǔ)的是用戶名和 md5 加密后的密碼:
login.php
<?php
// 表單提交后...
$posts = $_POST;
// 清除一些空白符號(hào)
foreach ($posts as $key => $value) {
$posts[$key] = trim($value);
}
$password = md5($posts["password"]);
$username = $posts["username"];
$query = "SELECT `username` FROM `user` WHERE `password` = '$password' AND `username` = '$username'";
// 取得查詢結(jié)果
$userInfo = $DB->getRow($query);
if (!empty($userInfo)) {
// 當(dāng)驗(yàn)證通過后,啟動(dòng) Session
session_start();
// 注冊(cè)登陸成功的 admin 變量,并賦值 true
$_SESSION["admin"] = true;
} else {
die("用戶名密碼錯(cuò)誤");
}
?>
我們?cè)谛枰脩趄?yàn)證的頁面啟動(dòng) Session,判斷是否登陸:
<?php
// 防止全局變量造成安全隱患
$admin = false;
// 啟動(dòng)會(huì)話,這步必不可少
session_start();
// 判斷是否登陸
if (isset($_SESSION["admin"]) && $_SESSION["admin"] === true) {
echo "您已經(jīng)成功登陸";
} else {
// 驗(yàn)證失敗,將 $_SESSION["admin"] 置為 false
$_SESSION["admin"] = false;
die("您無權(quán)訪問");
}
?>
是不是很簡(jiǎn)單呢?將 $_SESSION 看成是存儲(chǔ)在服務(wù)器端的數(shù)組即可,我們注冊(cè)的每一個(gè)變量都是數(shù)組的鍵,跟使用數(shù)組沒有什么分別。
如果要登出系統(tǒng)怎么辦?銷毀 Session 即可。
<?php
session_start();
// 這種方法是將原來注冊(cè)的某個(gè)變量銷毀
unset($_SESSION['admin']);
// 這種方法是銷毀整個(gè) Session 文件
session_destroy();
?>
Session 能否像 Cookie 那樣設(shè)置生存周期呢?有了 Session 是否就完全拋棄 Cookie 呢?我想說,結(jié)合 Cookie 來使用 Session 才是最方便的。
對(duì)于 Cookie 來說,假設(shè)我們要驗(yàn)證用戶是否登陸,就必須在 Cookie 中保存用戶名和密碼(可能是 md5 加密后字符串),并在每次請(qǐng)求頁面的時(shí)候進(jìn)行驗(yàn)證。如果用戶名和密碼存儲(chǔ)在數(shù)據(jù)庫,每次都要執(zhí)行一次數(shù)據(jù)庫查詢,給數(shù)據(jù)庫造成多余的負(fù)擔(dān)。因?yàn)槲覀儾⒉荒苤蛔鲆淮悟?yàn)證。為什么呢?因?yàn)榭蛻舳?nbsp;Cookie 中的信息是有可能被修改的。假如你存儲(chǔ) $admin 變量來表示用戶是否登陸,$admin 為 true 的時(shí)候表示登陸,為 false 的時(shí)候表示未登錄,在第一次通過驗(yàn)證后將 $admin 等于 true 存儲(chǔ)在 Cookie,下次就不用驗(yàn)證了,這樣對(duì)么?錯(cuò)了,假如有人偽造一個(gè)值為 true 的 $admin 變量那不是就立即取的了管理權(quán)限么?非常的不安全。
而 Session 就不同了,Session 是存儲(chǔ)在服務(wù)器端的,遠(yuǎn)程用戶沒辦法修改 Session 文件的內(nèi)容,因此我們可以單純存儲(chǔ)一個(gè) $admin 變量來判斷是否登陸,首次驗(yàn)證通過后設(shè)置 $admin 值為 true,以后判斷該值是否為 true,假如不是,轉(zhuǎn)入登陸界面,這樣就可以減少很多數(shù)據(jù)庫操作了。而且可以減少每次為了驗(yàn)證 Cookie 而傳遞密碼的不安全性了(Session 驗(yàn)證只需要傳遞一次,假如你沒有使用 SSL 安全協(xié)議的話)。即使密碼進(jìn)行了 md5 加密,也是很容易被截獲的。
當(dāng)然使用 Session 還有很多優(yōu)點(diǎn),比如控制容易,可以按照用戶自定義存儲(chǔ)等(存儲(chǔ)于數(shù)據(jù)庫)。我這里就不多說了。
Session 在 php.ini 是否需要設(shè)置呢?一般不需要的,因?yàn)椴⒉皇敲總€(gè)人都有修改 php.ini 的權(quán)限,默認(rèn) Session 的存放路徑是服務(wù)器的系統(tǒng)臨時(shí)文件夾,我們可以自定義存放在自己的文件夾里,這個(gè)稍后我會(huì)介紹。
開始介紹如何創(chuàng)建 Session。非常簡(jiǎn)單,真的。
啟動(dòng) Session 會(huì)話,并創(chuàng)建一個(gè) $admin 變量:
<?php
// 啟動(dòng) Session
session_start();
// 聲明一個(gè)名為 admin 的變量,并賦空值。
$_SESSION["admin"] = null;
?>
如果你使用了 Seesion,或者該 PHP 文件要調(diào)用 Session 變量,那么就必須在調(diào)用 Session 之前啟動(dòng)它,使用 session_start() 函數(shù)。其它都不需要你設(shè)置了,PHP 自動(dòng)完成 Session 文件的創(chuàng)建。
執(zhí)行完這個(gè)程序后,我們可以到系統(tǒng)臨時(shí)文件夾找到這個(gè) Session 文件,一般文件名形如:sess_4c83638b3b0dbf65583181c2f89168ec,后面是 32 位編碼后的隨機(jī)字符串。用編輯器打開它,看一下它的內(nèi)容:
admin|N; 一般該內(nèi)容是這樣的結(jié)構(gòu):
變量名|類型:長(zhǎng)度:值; 并用分號(hào)隔開每個(gè)變量。有些是可以省略的,比如長(zhǎng)度和類型。
我們來看一下驗(yàn)證程序,假設(shè)數(shù)據(jù)庫存儲(chǔ)的是用戶名和 md5 加密后的密碼:
login.php
<?php
// 表單提交后...
$posts = $_POST;
// 清除一些空白符號(hào)
foreach ($posts as $key => $value) {
$posts[$key] = trim($value);
}
$password = md5($posts["password"]);
$username = $posts["username"];
$query = "SELECT `username` FROM `user` WHERE `password` = '$password' AND `username` = '$username'";
// 取得查詢結(jié)果
$userInfo = $DB->getRow($query);
if (!empty($userInfo)) {
// 當(dāng)驗(yàn)證通過后,啟動(dòng) Session
session_start();
// 注冊(cè)登陸成功的 admin 變量,并賦值 true
$_SESSION["admin"] = true;
} else {
die("用戶名密碼錯(cuò)誤");
}
?>
我們?cè)谛枰脩趄?yàn)證的頁面啟動(dòng) Session,判斷是否登陸:
<?php
// 防止全局變量造成安全隱患
$admin = false;
// 啟動(dòng)會(huì)話,這步必不可少
session_start();
// 判斷是否登陸
if (isset($_SESSION["admin"]) && $_SESSION["admin"] === true) {
echo "您已經(jīng)成功登陸";
} else {
// 驗(yàn)證失敗,將 $_SESSION["admin"] 置為 false
$_SESSION["admin"] = false;
die("您無權(quán)訪問");
}
?>
是不是很簡(jiǎn)單呢?將 $_SESSION 看成是存儲(chǔ)在服務(wù)器端的數(shù)組即可,我們注冊(cè)的每一個(gè)變量都是數(shù)組的鍵,跟使用數(shù)組沒有什么分別。
如果要登出系統(tǒng)怎么辦?銷毀 Session 即可。
<?php
session_start();
// 這種方法是將原來注冊(cè)的某個(gè)變量銷毀
unset($_SESSION['admin']);
// 這種方法是銷毀整個(gè) Session 文件
session_destroy();
?>
Session 能否像 Cookie 那樣設(shè)置生存周期呢?有了 Session 是否就完全拋棄 Cookie 呢?我想說,結(jié)合 Cookie 來使用 Session 才是最方便的。
您可能感興趣的文章:
- php array_udiff_assoc 計(jì)算兩個(gè)數(shù)組的差集實(shí)例
- php實(shí)現(xiàn)的SSO單點(diǎn)登錄系統(tǒng)接入功能示例分析
- SSO單點(diǎn)登錄的PHP實(shí)現(xiàn)方法(Laravel框架)
- PHP中SSO Cookie登錄分析和實(shí)現(xiàn)
- php的sso單點(diǎn)登錄實(shí)現(xiàn)方法
- php調(diào)用方法mssql_fetch_row、mssql_fetch_array、mssql_fetch_assoc和mssql_fetch_objcect讀取數(shù)據(jù)的區(qū)別
- PHP數(shù)組的交集array_intersect(),array_intersect_assoc(),array_inter_key()函數(shù)的小問題
- php中處理mysql_fetch_assoc返回來的數(shù)組 不用foreach----echo
- PHP編程 SSO詳細(xì)介紹及簡(jiǎn)單實(shí)例
相關(guān)文章
php+mysql事務(wù)rollback&commit示例
執(zhí)行BEGIN之后,其作用同set autocommit=0,而且之后設(shè)置set autocommit=0或1時(shí)無效。所以,為使操作清楚,一般不使用BEGIN。2010-02-02
php+js實(shí)現(xiàn)的拖動(dòng)滑塊驗(yàn)證碼驗(yàn)證表單操作示例【附源碼下載】
這篇文章主要介紹了php+js實(shí)現(xiàn)的拖動(dòng)滑塊驗(yàn)證碼驗(yàn)證表單操作,結(jié)合實(shí)例形式分析了php+js拖動(dòng)滑塊驗(yàn)證碼驗(yàn)證表單操作基本功能實(shí)現(xiàn)與使用相關(guān)操作技巧,需要的朋友可以參考下2020-05-05
file_get_contents("php://input", "r")實(shí)例介
本篇文章是對(duì)file_get_contents("php://input", "r")的實(shí)例進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-07-07
PHP 雜談《重構(gòu)-改善既有代碼的設(shè)計(jì)》之三 重新組織數(shù)據(jù)
承接上文的PHP 雜談《重構(gòu)-改善既有代碼的設(shè)計(jì)》之 重新組織你的函數(shù)繼續(xù)重構(gòu)方面的內(nèi)容2012-04-04
基于PHP實(shí)現(xiàn)用戶登錄注冊(cè)功能的詳細(xì)教程
這篇文章主要介紹了基于PHP實(shí)現(xiàn)用戶登錄注冊(cè)功能的詳細(xì)教程,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-08-08
解析php session_set_save_handler 函數(shù)的用法(mysql)
本篇文章是對(duì)php中session_set_save_handler 函數(shù)的用法(mysql)進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-06-06
WordPress中用于獲取文章信息以及分類鏈接的函數(shù)用法
這篇文章主要介紹了WordPress中用于獲取文章信息以及分類鏈接的函數(shù)用法,分別是get_post()和get_category_link()的使用,需要的朋友可以參考下2015-12-12
php+mysqli批量查詢多張表數(shù)據(jù)的方法
這篇文章主要介紹了php+mysqli批量查詢多張表數(shù)據(jù)的方法,涉及multi_query、store_result及more_results等函數(shù)的使用技巧,需要的朋友可以參考下2015-01-01

