国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 網站 > 幫助中心 > 正文

推薦學習php sesson的朋友必看PHP會話(Session)使用入門

2024-07-09 22:41:43
字體:
來源:轉載
供稿:網友
 由于 Session 是以文本文件形式存儲在服務器端的,所以不怕客戶端修改 Session 內容。實際上在服務器端的 Session 文件,PHP 自動修改 Session 文件的權限,只保留了系統讀和寫權限,而且不能通過 ftp 修改,所以安全得多。
對于 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 還有很多優點,比如控制容易,可以按照用戶自定義存儲等(存儲于數據庫)。我這里就不多說了。
Session 在 php.ini 是否需要設置呢?一般不需要的,因為并不是每個人都有修改 php.ini 的權限,默認 Session 的存放路徑是服務器的系統臨時文件夾,我們可以自定義存放在自己的文件夾里,這個稍后我會介紹。
開始介紹如何創建 Session。非常簡單,真的。
啟動 Session 會話,并創建一個 $admin 變量:

<?php 
//  啟動 Session 
session_start(); 
//  聲明一個名為 admin 的變量,并賦空值。 
$_SESSION["admin"] = null; 
?>
  如果你使用了 Seesion,或者該 PHP 文件要調用 Session 變量,那么就必須在調用 Session 之前啟動它,使用 session_start() 函數。其它都不需要你設置了,PHP 自動完成 Session 文件的創建。

  執行完這個程序后,我們可以到系統臨時文件夾找到這個 Session 文件,一般文件名形如:sess_4c83638b3b0dbf65583181c2f89168ec,后面是 32 位編碼后的隨機字符串。用編輯器打開它,看一下它的內容:

admin|N; 一般該內容是這樣的結構:

變量名|類型:長度:值;   并用分號隔開每個變量。有些是可以省略的,比如長度和類型。

  我們來看一下驗證程序,假設數據庫存儲的是用戶名和 md5 加密后的密碼:

login.php
<?php 
//  表單提交后... 
$posts = $_POST; 
//  清除一些空白符號 
foreach ($posts as $key => $value) {
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 台山市| 霸州市| 睢宁县| 清镇市| 建瓯市| 连州市| 丰顺县| 北碚区| 额尔古纳市| 留坝县| 武汉市| 清水县| 大英县| 永善县| 汤阴县| 平遥县| 高唐县| 大余县| 滁州市| 三台县| 禄丰县| 新津县| 长沙县| 福清市| 古丈县| 长武县| 西宁市| 泰和县| 建湖县| 小金县| 永和县| 泰宁县| 永州市| 大化| 大关县| 安平县| 乌鲁木齐市| 呈贡县| 工布江达县| 无极县| 扎赉特旗|