IT貓撲網(wǎng):您身邊最放心的安全下載站! 最新更新|軟件分類(lèi)|軟件專(zhuān)題|手機(jī)版|論壇轉(zhuǎn)貼|軟件發(fā)布

您當(dāng)前所在位置: 首頁(yè)網(wǎng)絡(luò)編程PHP編程 → PHP會(huì)話Session的具體使用方法解析

PHP會(huì)話Session的具體使用方法解析

時(shí)間:2015-06-28 00:00:00 來(lái)源:IT貓撲網(wǎng) 作者:網(wǎng)管聯(lián)盟 我要評(píng)論(1)

PHP會(huì)話Session的御用比起Cookie來(lái)說(shuō)相對(duì)要更安全一些,而且沒(méi)有數(shù)據(jù)長(zhǎng)度的限制。我們今天就向大家介紹有關(guān)PHP會(huì)話Session一些相關(guān)知識(shí),以加深民大家對(duì)PHP會(huì)話Session的認(rèn)識(shí)程度。

由于 Session 是以文本文件形式存儲(chǔ)在服務(wù)器端的,所以不怕客戶端修改 Session 內(nèi)容。實(shí)際上在服務(wù)器端的 Session 文件,PHP 自動(dòng)修改 Session 文件的權(quán)限,只保留了系統(tǒng)讀和寫(xiě)權(quán)限,而且不能通過(guò) ftp 修改,所以安全得多。

對(duì)于 Cookie 來(lái)說(shuō),假設(shè)我們要驗(yàn)證用戶是否登陸,就必須在 Cookie 中保存用戶名和密碼(可能是 md5 加密后字符串),并在每次請(qǐng)求頁(yè)面的時(shí)候進(jìn)行驗(yàn)證。如果用戶名和密碼存儲(chǔ)在數(shù)據(jù)庫(kù),每次都要執(zhí)行一次數(shù)據(jù)庫(kù)查詢,給數(shù)據(jù)庫(kù)造成多余的負(fù)擔(dān)。因?yàn)槲覀儾⒉荒?只做一次驗(yàn)證。為什么呢?因?yàn)榭蛻舳?Cookie 中的信息是有可能被修改的。假如你存儲(chǔ) $admin 變量來(lái)表示用戶是否登陸,$admin 為 true 的時(shí)候表示登陸,為 false 的時(shí)候表示未登錄,在第一次通過(guò)驗(yàn)證后將 $admin 等于 true 存儲(chǔ)在 Cookie,下次就不用驗(yàn)證了,這樣對(duì)么?錯(cuò)了,假如有人偽造一個(gè)值為 true 的 $admin 變量那不是就立即取的了管理權(quán)限么?非常的不安全。

而PHP會(huì)話Session就不同了,Session 是存儲(chǔ)在服務(wù)器端的,遠(yuǎn)程用戶沒(méi)辦法修改 Session 文件的內(nèi)容,因此我們可以單純存儲(chǔ)一個(gè) $admin 變量來(lái)判斷是否登陸,首次驗(yàn)證通過(guò)后設(shè)置 $admin 值為 true,以后判斷該值是否為 true,假如不是,轉(zhuǎn)入登陸界面,這樣就可以減少很多數(shù)據(jù)庫(kù)操作了。而且可以減少每次為了驗(yàn)證 Cookie 而傳遞密碼的不安全性了(Session 驗(yàn)證只需要傳遞一次,假如你沒(méi)有使用 SSL 安全協(xié)議的話)。即使密碼進(jìn)行了 md5 加密,也是很容易被截獲的。

當(dāng)然使用 Session 還有很多優(yōu)點(diǎn),比如控制容易,可以按照用戶自定義存儲(chǔ)等(存儲(chǔ)于數(shù)據(jù)庫(kù))。我這里就不多說(shuō)了。

PHP會(huì)話Session在 php.ini 是否需要設(shè)置呢?一般不需要的,因?yàn)椴⒉皇敲總€(gè)人都有修改 php.ini 的權(quán)限,默認(rèn) Session 的存放路徑是服務(wù)器的系統(tǒng)臨時(shí)文件夾,我們可以自定義存放在自己的文件夾里,這個(gè)稍后我會(huì)介紹。

開(kāi)始介紹如何創(chuàng)建 Session。非常簡(jiǎn)單,真的。

啟動(dòng) Session 會(huì)話,并創(chuàng)建一個(gè) $admin 變量:

  1. //?啟動(dòng)?Session? ?
  2. session_start();? ?
  3. //?聲明一個(gè)名為?admin?的變量,并賦空值。? ?
  4. $_SESSION["admin"]?=?null;? ?
  5. ?>?

如果你使用了 Seesion,或者該 PHP 文件要調(diào)用 Session 變量,那么就必須在調(diào)用PHP會(huì)話Session之前啟動(dòng)它,使用 session_start() 函數(shù)。其它都不需要你設(shè)置了,PHP 自動(dòng)完成 Session 文件的創(chuàng)建。

執(zhí)行完這個(gè)程序后,我們可以到系統(tǒng)臨時(shí)文件夾找到這個(gè) Session 文件,一般文件名形如:sess_4c83638b3b0dbf65583181c2f89168ec,后面是 32 位編碼后的隨機(jī)字符串。用編輯器打開(kāi)它,看一下它的內(nèi)容:

admin|N;

一般該內(nèi)容是這樣的結(jié)構(gòu):

變量名|類(lèi)型:長(zhǎng)度:值;

并用分號(hào)隔開(kāi)每個(gè)變量。有些是可以省略的,比如長(zhǎng)度和類(lèi)型。

我們來(lái)看一下驗(yàn)證程序,假設(shè)數(shù)據(jù)庫(kù)存儲(chǔ)的是用戶名和 md5 加密后的密碼:

  1. login.php ?
  2. ?
  3. //?表單提交后...? ?
  4. $posts?=?$_POST;? ?
  5. //?清除一些空白符號(hào)? ?
  6. foreach?($posts?as?$key?=>?$value)? ?
  7. {? ?
  8. $posts[$key]?=?trim($value);? ?
  9. }? ?
  10. $password?=?md5($posts["password"]);? ?
  11. $username?=?$posts["username"]; ?
  12. ?
  13. $query?=?"SELECT?`username`?FROM?`user`?WHERE?`password`?=?'$password'";? ?
  14. //?取得查詢結(jié)果? ?
  15. $userInfo?=?$DB->getRow($query); ?
  16. ?
  17. if?(!empty($userInfo))? ?
  18. {? ?
  19. if?($userInfo["username"]?==?$username)? ?
  20. {? ?
  21. //?當(dāng)驗(yàn)證通過(guò)后,啟動(dòng)PHP會(huì)話Session
  22. session_start();? ?
  23. //?注冊(cè)登陸成功的?admin?變量,并賦值?true? ?
  24. $_SESSION["admin"]?=?true;? ?
  25. }? ?
  26. else? ?
  27. {? ?
  28. die("用戶名密碼錯(cuò)誤");? ?
  29. }? ?
  30. }? ?
  31. else? ?
  32. {? ?
  33. die("用戶名密碼錯(cuò)誤");? ?
  34. } ?
  35. ?
  36. ?>?

我們?cè)谛枰脩趄?yàn)證的頁(yè)面啟動(dòng) Session,判斷是否登陸:

  1. //?防止全局變量造成安全隱患? ?
  2. $admin?=?false; ?
  3. ?
  4. //?啟動(dòng)會(huì)話,這步必不可少? ?
  5. session_start(); ?
  6. ?
  7. //?判斷是否登陸? ?
  8. if?(isset($_SESSION["admin"])?&&?$_SESSION["admin"]?===?true)? ?
  9. {? ?
  10. echo?"您已經(jīng)成功登陸";? ?
  11. }? ?
  12. else? ?
  13. {? ?
  14. //?驗(yàn)證失敗,將?$_SESSION["admin"]?置為?false ?
  15. $_SESSION["admin"]?=?false;? ?
  16. die("您無(wú)權(quán)訪問(wèn)");? ?
  17. } ?
  18. ?
  19. ?>?

是不是很簡(jiǎn)單呢?將 $_SESSION 看成是存儲(chǔ)在服務(wù)器端的數(shù)組即可,我們注冊(cè)的每一個(gè)變量都是數(shù)組的鍵,跟使用數(shù)組沒(méi)有什么分別。

如果要登出系統(tǒng)怎么辦?銷(xiāo)毀PHP會(huì)話Session即可。

#p#副標(biāo)題#e#

  1. session_start();? ?
  2. //?這種方法是將原來(lái)注冊(cè)的某個(gè)變量銷(xiāo)毀 ?
  3. unset($_SESSION["admin"]); ?
  4. ?關(guān)鍵詞標(biāo)簽:PHP會(huì)話Session

相關(guān)閱讀

文章評(píng)論
發(fā)表評(píng)論

熱門(mén)文章 plsql developer怎么連接數(shù)據(jù)庫(kù)-plsql developer連接數(shù)據(jù)庫(kù)方法 plsql developer怎么連接數(shù)據(jù)庫(kù)-plsql developer連接數(shù)據(jù)庫(kù)方法 2021年最好用的10款php開(kāi)發(fā)工具推薦 2021年最好用的10款php開(kāi)發(fā)工具推薦 php利用淘寶IP庫(kù)獲取用戶ip地理位置 php利用淘寶IP庫(kù)獲取用戶ip地理位置 在 PHP 中使用命令行工具 在 PHP 中使用命令行工具

相關(guān)下載

人氣排行 詳解ucenter原理及第三方應(yīng)用程序整合思路、方法 plsql developer怎么連接數(shù)據(jù)庫(kù)-plsql developer連接數(shù)據(jù)庫(kù)方法 PHP中防止SQL注入攻擊 PHP會(huì)話Session的具體使用方法解析 PHP運(yùn)行出現(xiàn)Notice : Use of undefined constant 的解決辦法 PHP如何清空mySQL數(shù)據(jù)庫(kù) CakePHP程序員必須知道的21條技巧 PHP采集圖片實(shí)例(PHP采集)