php開發中session使用

來源:互聯網
上載者:User

在PHP開發中對比起Cookie,session是儲存在伺服器端的會話,相對安全,並且不像Cookie那樣有儲存長度限制,本文簡單介紹session的使用。

由於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 加密後的密碼:

<?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'";
// 取得查詢結果
$userInfo = $DB->getRow($query);

if (!empty($userInfo))
{
if ($userInfo["username"] == $username)
{
// 當驗證通過後,啟動 session
session_start();
// 註冊登陸成功的 admin 變數,並賦值 true
$_session["admin"] = true;
}
else
{
 die("使用者名稱密碼錯誤");
}
 }
else
{
die("使用者名稱密碼錯誤");
}

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.