PHP Cookie和Session

一、PHP Cookie

cookie 常用於識別用戶。

1.1 Cookie 是什麼?

cookie 常用於識別用戶。cookie 是一種服務器留在用戶計算機上的小文件。每當同一臺計算機通過瀏覽器請求頁面時,這臺計算機將會發送 cookie。通過 PHP,你能夠創建並取回 cookie 的值。

1.2 如何創建 Cookie?

setcookie() 函數用於設置 cookie。

註釋:setcookie() 函數必須位於 <html> 標籤之前。

語法 :

setcookie(name, value, expire, path, domain);
  1. 實例 1

在下面的例子中,我們將創建名爲 "user" 的 cookie,併爲它賦值 "runoob"。我們也規定了此 cookie 在一小時後過期:

<?php
setcookie("user", "runoob", time()+3600);
?>
​
<html>
.....

註釋:在發送 cookie 時,cookie 的值會自動進行 URL 編碼,在取回時進行自動解碼。(爲防止 URL 編碼,請使用 setrawcookie() 取而代之。)

  1. 實例 2

你還可以通過另一種方式設置 cookie 的過期時間。這也許比使用秒錶示的方式簡單。

<?php
$expire=time()+60*60*24*30;
setcookie("user", "runoob", $expire);
?>
​
<html>
.....

在上面的實例中,過期時間被設置爲一個月(60 秒 * 60 分 * 24 小時 * 30 天)。

1.3 如何取回 Cookie 的值?

PHP 的 $_COOKIE 變量用於取回 cookie 的值。

在下面的實例中,我們取回了名爲 "user" 的 cookie 的值,並把它顯示在了頁面上:

<?php
// 輸出 cookie 值
echo $_COOKIE["user"];
​
// 查看所有 cookie
print_r($_COOKIE);
?>

在下面的實例中,我們使用 isset() 函數來確認是否已設置了 cookie:

<html>
<head>
<meta charset="utf-8">
<title>菜鳥教程(runoob.com)</title>
</head>
<body>
​
<?php
if (isset($_COOKIE["user"]))
    echo "歡迎 " . $_COOKIE["user"] . "!<br>";
else
    echo "普通訪客!<br>";
?>
​
</body>
</html>

1.4 如何刪除 Cookie?

當刪除 cookie 時,你應當使過期日期變更爲過去的時間點。

<?php
// 設置 cookie 過期時間爲過去 1 小時
setcookie("user", "", time()-3600);
?>

1.5 如果瀏覽器不支持 Cookie 該怎麼辦?

如果你的應用程序需要與不支持 cookie 的瀏覽器打交道,那麼你不得不使用其他的辦法在你的應用程序中的頁面之間傳遞信息。一種方式是通過表單傳遞數據(有關表單和用戶輸入的內容,在本教程的前面章節中我們已經介紹過了)。

下面的表單在用戶單點擊 "Submit" 按鈕時,向 "welcome.php" 提交了用戶輸入:

<html>
<head>
<meta charset="utf-8">
<title>菜鳥教程(runoob.com)</title>
</head>
<body>
​
<form action="welcome.php" method="post">
名字: <input type="text" name="name">
年齡: <input type="text" name="age">
<input type="submit">
</form>
​
</body>
</html>
​

取回 "welcome.php" 文件中的值,如下所示:

<html>
<head>
<meta charset="utf-8">
<title>菜鳥教程(runoob.com)</title>
</head>
<body>
​
歡迎 <?php echo $_POST["name"]; ?>.<br>
你 <?php echo $_POST["age"]; ?> 歲了。
​
</body>
</html>

二、PHP Session

PHP session 變量用於存儲關於用戶會話(session)的信息,或者更改用戶會話(session)的設置。Session 變量存儲單一用戶的信息,並且對於應用程序中的所有頁面都是可用的。

2.1 PHP Session 變量

你在計算機上操作某個應用程序時,你打開它,做些更改,然後關閉它。這很像一次對話(Session)。計算機知道你是誰。它清楚你在何時打開和關閉應用程序。然而,在因特網上問題出現了:由於 HTTP 地址無法保持狀態,Web 服務器並不知道你是誰以及你做了什麼。

PHP session 解決了這個問題,它通過在服務器上存儲用戶信息以便隨後使用(比如用戶名稱、購買商品等)。然而,會話信息是臨時的,在用戶離開網站後將被刪除。如果你需要永久存儲信息,可以把數據存儲在數據庫中。

Session 的工作機制是:爲每個訪客創建一個唯一的 id (UID),並基於這個 UID 來存儲變量。UID 存儲在 cookie 中,或者通過 URL 進行傳導。

2.2 開始 PHP Session

在你把用戶信息存儲到 PHP session 中之前,首先必須啓動會話。

註釋:session_start() 函數必須位於 <html> 標籤之前:

<?php session_start(); ?>
​
<html>
<body>
......
</body>
</html>

上面的代碼會向服務器註冊用戶的會話,以便你可以開始保存用戶信息,同時會爲用戶會話分配一個 UID。

2.3 存儲 Session 變量

存儲和取回 session 變量的正確方法是使用 PHP $_SESSION 變量:

<?php
session_start();
// 存儲 session 數據
$_SESSION['views']=1;
?>
​
<html>
<head>
<meta charset="utf-8">
<title>菜鳥教程(runoob.com)</title>
</head>
<body>
​
<?php
// 檢索 session 數據
echo "瀏覽量:". $_SESSION['views'];
?>
​
</body>
</html>

輸出:

瀏覽量:1

在下面的實例中,我們創建了一個簡單的 page-view 計數器。isset() 函數檢測是否已設置 "views" 變量。如果已設置 "views" 變量,我們累加計數器。如果 "views" 不存在,則創建 "views" 變量,並把它設置爲 1:

<?php
session_start();
​
if(isset($_SESSION['views']))
{
    $_SESSION['views']=$_SESSION['views']+1;
}
else
{
    $_SESSION['views']=1;
}
echo "瀏覽量:". $_SESSION['views'];
?>

2.4 銷燬 Session

如果你希望刪除某些 session 數據,可以使用 unset() 或 session_destroy() 函數。

unset() 函數用於釋放指定的 session 變量:

<?php
session_start();
if(isset($_SESSION['views']))
{
    unset($_SESSION['views']);
}
?>

你也可以通過調用 session_destroy() 函數徹底銷燬 session:

<?php
session_destroy();
?>

註釋:session_destroy() 將重置 session,你將失去所有已存儲的 session 數據。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章