一区二区久久-一区二区三区www-一区二区三区久久-一区二区三区久久精品-麻豆国产一区二区在线观看-麻豆国产视频

推薦學(xué)習(xí)php sesson的朋友必看PHP會(huì)話(Session)使用入門(mén)第1/2頁(yè)

 由于 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)榭蛻舳?nbsp;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)限么?非常的不安全。
而 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ō)了。
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 變量:

<?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ī)字符串。用編輯器打開(kāi)它,看一下它的內(nèi)容:

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

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

  我們來(lái)看一下驗(yàn)證程序,假設(shè)數(shù)據(jù)庫(kù)存儲(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)證通過(guò)后,啟動(dòng) Session 
    session_start(); 
    //  注冊(cè)登陸成功的 admin 變量,并賦值 true 
    $_SESSION["admin"] = true;  
} else { 
    die("用戶名密碼錯(cuò)誤"); 

?>
  我們?cè)谛枰脩趄?yàn)證的頁(yè)面啟動(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("您無(wú)權(quán)訪問(wèn)"); 

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

  如果要登出系統(tǒng)怎么辦?銷毀 Session 即可。

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

php技術(shù)推薦學(xué)習(xí)php sesson的朋友必看PHP會(huì)話(Session)使用入門(mén)第1/2頁(yè),轉(zhuǎn)載需保留來(lái)源!

鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請(qǐng)第一時(shí)間聯(lián)系我們修改或刪除,多謝。

主站蜘蛛池模板: 日本三区| 中文字幕国产 | 国产综合精品一区二区 | 色噜噜噜噜噜 | 中国毛片免费观看 | 激情视频小说图片 | 98香蕉草草视频在线精品看 | 国产精品hd| 最新毛片网站 | 色月| 精品日本久久久久久久久久 | 国产一区系列在线观看 | 免费人成网站尤物在线观看 | 久久综合久久鬼 | 久久怡红院国产精品 | 九九精品久久 | 美女国产| 国产精品婷婷久青青原 | 欧美激情乱人伦 | 国内精品久久久久久影院老狼 | 9久9久女女热精品视频免费观看 | 玖玖玖精品视频免费播放 | 亚洲国产视频网 | 免费99精品国产自在现线观看 | 国产精品自在自线 | 婷婷色九月综合激情丁香 | 国产精品第 | 秋霞日韩一区二区三区在线观看 | 亚洲一区二区福利视频 | 中文字幕久久综合 | 五月婷婷开心网 | 亚洲激情在线视频 | 深夜福利一区二区 | 亚洲综合区小说区激情区噜噜 | 国产精品美女一区二区 | 国产拍拍视频一二三四区 | 丁香六月婷婷 | 国产午夜看片 | 性xxxxxxxxx18欧美 | 久久91精品国产91久 | 一区二区三区成人 |