成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

學習筆記:談談PHP Session使用方法

開發 后端
Session 是以文本文件形式存儲在服務器端的,所以不怕客戶端修改 Session 內容,文章詳細的介紹了PHP Session使用。

PHP有很多值得學習的地方,這里我們主要介紹PHP Session使用。在PHP開發中對比起Cookie,session 是存儲在服務器端的會話,相對安全,并且不像 Cookie 那樣有存儲長度限制,下面我們就簡單介紹 PHP Session使用。

#T#由于 Session 是以文本文件形式存儲在服務器端的,所以不怕客戶端修改 Session 內容。實際上在服務器端的 Session 文件,PHP 自動修改 session 文件的權限,只保留了系統讀和寫權限,而且不能通過 ftp 修改,所以安全得多。PHPChina 開源社區門戶對于 Cookie 來說,假設我們要驗證用戶是否登陸,就必須在 Cookie 中保存用戶名和密碼(可能是 md5 加密后字符串),并在每次請求頁面的時候進行驗證。如果用戶名和密碼存儲在數據庫,每次都要執行一次數據庫查詢,給數據庫造成多余的負擔。

因為我們并不能只做一次驗證。為什么呢?因為客戶端 Cookie 中的信息是有可能被修改的。假如你存儲 $admin 變量來表示用戶是否登陸,$admin 為 true 的時候表示登陸,為 false 的時候表示未登錄,在第一次通過驗證后將 $admin 等于 true 存儲在 Cookie,下次就不用驗證了,這樣對么?錯了,假如有人偽造一個值為 true 的 $admin 變量那不是就立即取的了管理權限么?非常的不安全。

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

當然使用 session 還有很多優點,比如控制容易,可以按照用戶自定義存儲等(存儲于數據庫)。我這里就不多說了。PHP Session使用在 php.ini 是否需要設置呢?一般不需要的,因為并不是每個人都有修改 PHP.ini 的權限,默認 session 的存放路徑是服務器的系統臨時文件夾,我們可以自定義存放在自己的文件夾里,這個稍后我會介紹。

開始介紹如何創建 session。非常簡單,真的。啟動 session 會話,并創建一個 $admin 變量:

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

如果你使用了 Seesion,或者該 PHP 文件要調用 Session 變量,那么就必須在調用 Session 之前啟動它,使用 session_start() 函數。其它都不需要你設置了,PHP 自動完成 session 文件的創建。執行完這個程序后,我們可以到系統臨時文件夾找到這個 session 文件,一般文件名形如:sess_4c83638b3b0dbf65583181c2f89168ec,后面是 32 位編碼后的隨機字符串。用編輯器打開它,看一下它的內容:

一般該內容是這樣的結構:

  1. // 表單提交后...  
  2. $posts = $_POST;  
  3. // 清除一些空白符號  
  4. foreach ($posts as $key => $value)  
  5. {  
  6. $posts[$key] = trim($value);  
  7. }  
  8. $password = md5($posts["password"]);  
  9. $username = $posts["username"];  
  10. $query = "SELECT `username` FROM `user` WHERE `password` = '$password'";  
  11. // 取得查詢結果  
  12. $userInfo = $DB->getRow($query);  
  13. if (!empty($userInfo))  
  14. {  
  15. if ($userInfo["username"] == $username)  
  16. {  
  17. // 當驗證通過后,啟動 session  
  18. session_start();  
  19. // 注冊登陸成功的 admin 變量,并賦值 true  
  20. $_session["admin"] = true;  
  21. }  
  22. else  
  23. {  
  24. die("用戶名密碼錯誤");  
  25. }  
  26. }  
  27. else  
  28. {  
  29. die("用戶名密碼錯誤");  
  30. }  
  31. 我們在需要用戶驗證的頁面啟動 session,判斷是否登陸:  
  32. // 防止全局變量造成安全隱患  
  33. $admin = false;  
  34. // 啟動會話,這步必不可少  
  35. session_start();  
  36. // 判斷是否登陸  
  37. if (isset($_SESSION["admin"]) && $_session["admin"] === true)  
  38. {  
  39. echo "您已經成功登陸";  
  40. }  
  41. else  
  42. {  
  43. // 驗證失敗,將 $_session["admin"] 置為 false  
  44. $_session["admin"] = false;  
  45. die("您無權訪問");  
  46. }  
  47. ?> 


是不是很簡單呢?將 $_session 看成是存儲在服務器端的數組即可,我們注冊的每一個變量都是數組的鍵,跟使用數組沒有什么分別。

責任編輯:田樹 來源: it168
相關推薦

2009-11-17 17:38:37

PHP Session

2009-11-25 10:02:27

PHP會話Sessio

2010-06-01 19:55:30

SVN使用

2009-11-16 15:40:58

PHP數組函數

2009-12-02 16:04:44

PHP fsockop

2009-12-02 15:02:09

PHP simplex

2010-07-09 14:39:42

UML類圖

2009-12-02 18:51:12

PHP分頁類

2009-11-16 16:54:00

PHP構造函數

2009-11-17 15:00:19

PHP遍歷數組

2011-06-16 11:01:56

PHP繼承

2009-12-07 16:52:59

PHP函數getima

2009-11-30 17:43:54

PHP split()

2009-11-24 15:50:09

PHP上傳類uploa

2011-07-12 17:11:13

PHPSHELL

2009-11-16 13:57:21

PHP上傳文件

2009-11-24 19:25:32

PHP關聯數組

2009-11-26 15:23:24

PHP函數ereg()

2011-07-12 17:18:23

PHPstrtotime

2009-11-26 19:05:04

PHP函數explod
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: www.中文字幕.com | 欧美精品一区二区三区在线四季 | 色爱综合网 | 亚洲一区二区在线视频 | 99精品国产一区二区三区 | 中文字幕一区二区三区在线乱码 | 国产91网址 | 国产一区二区在线91 | av中文字幕在线 | 91欧美激情一区二区三区成人 | 久久久久国产一级毛片 | 欧州一区二区 | 成人在线视频观看 | 国产一区二区三区四区三区四 | 玖玖玖在线 | 欧美日韩精品免费观看 | 国产一区二区在线91 | 亚洲人成人一区二区在线观看 | av福利网 | 少妇午夜一级艳片欧美精品 | 成年人在线视频 | 91 在线| 龙珠z在线观看 | 久草在线 | 在线一级片 | 黄色网址在线免费观看 | 三级视频网站 | 特黄视频| 亚洲永久 | 欧美黑人激情 | 日本三级全黄三级a | 国产精品成人在线观看 | 欧美精品一区二区三区在线播放 | 91精品国产一区二区在线观看 | 伊人伊成久久人综合网站 | 成人在线电影网站 | 亚洲成人精品国产 | 亚洲视频免费一区 | 国产精品一区二区久久久久 | 日韩av免费在线观看 | 久久999|