天天躁日日躁狠狠躁AV麻豆-天天躁人人躁人人躁狂躁-天天澡夜夜澡人人澡-天天影视香色欲综合网-国产成人女人在线视频观看-国产成人女人视频在线观看

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

 由于 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) {
    $posts[$key] = trim($value); 

$password = md5($posts["password"]); 
$username = $posts["username"]; 

$query = "SELECT `username` FROM `user` WHERE `password` = '$password' AND `username` = '$username'"; 
//  取得查詢結果 
$userInfo = $DB->getRow($query); 

if (!empty($userInfo)) { 
    //  當驗證通過后,啟動 Session 
    session_start(); 
    //  注冊登陸成功的 admin 變量,并賦值 true 
    $_SESSION["admin"] = true;  
} else { 
    die("用戶名密碼錯誤"); 

?>
  我們在需要用戶驗證的頁面啟動 Session,判斷是否登陸:

<?php 
//  防止全局變量造成安全隱患 
$admin = false; 
//  啟動會話,這步必不可少 
session_start(); 
//  判斷是否登陸 
if (isset($_SESSION["admin"]) && $_SESSION["admin"] === true) { 
    echo "您已經成功登陸"; 
} else { 
    //  驗證失敗,將 $_SESSION["admin"] 置為 false
    $_SESSION["admin"] = false; 
    die("您無權訪問"); 

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

  如果要登出系統怎么辦?銷毀 Session 即可。

<?php 
session_start(); 
//  這種方法是將原來注冊的某個變量銷毀
unset($_SESSION['admin']); 
//  這種方法是銷毀整個 Session 文件
session_destroy(); 
?>
  Session 能否像 Cookie 那樣設置生存周期呢?有了 Session 是否就完全拋棄 Cookie 呢?我想說,結合 Cookie 來使用 Session 才是最方便的。

php技術推薦學習php sesson的朋友必看PHP會話(Session)使用入門第1/2頁,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 亚欧免费观看在线观看更新 | 视频一区亚洲视频无码 | 啦啦啦 中国 日本 高清 在线 | 伊人天天躁夜夜躁狠狠 | 国产成人aaa在线视频免费观看 | 久爱在线中文在观看 | 欧美成人中文字幕在线看 | 99视频在线观看免费视频 | 四虎精品久久久久影院 | 快播最新电影网站 | 无人视频在线观看免费播放影院 | 秘密教学26我们在做一次吧免费 | 久久无码人妻AV精品一区 | 骚浪插深些好烫喷了 | 国产亚洲精品久久久久久一区二区 | 青春草国产成人精品久久 | 处初女处夜情视频在线播放 | 鬼灭之刃花街篇免费樱花动漫 | 欧美性appstin孕妇 | 日韩欧美中文字幕在线二视频 | 国产人妻人伦精品熟女麻豆 | 午夜福利在线观看6080 | 99RE6这里只有精品国产AV | 国产AV亚洲精品久久久久软件 | 国产精品毛片在线视频 | 好姑娘社区在线视频 | 2020美女视频黄频大全视频 | 影音先锋男人av橹橹色 | 99无人区码一码二码三 | 国产精品一区二区人妻无码 | 日本人娇小hd | 亚洲欧美中文字幕网站大全 | 我的美女房东未删减版免费观看 | 总裁呻吟双腿大开男男H | 97亚洲狠狠色综合久久位 | 丰满五十老女人性视频 | 日韩欧美中文字幕一区 | 久久合 | 亚洲AV久久无码精品九号 | younv 学生国产在线视频 | 天美传媒在线完整免费观看网站 |