1. 程式人生 > >第113+114+115+116講 cookie①-cookie原理介紹 建立cookie獲取cookie

第113+114+115+116講 cookie①-cookie原理介紹 建立cookie獲取cookie

image
image
image
image
image

cookies win7路徑

C:\Users\Administrator\AppData\Roaming\Microsoft\Windows\Cookies

cookie

Cookie,有時也用其複數形式 Cookies,指某些網站為了辨別使用者身份、進行 session 跟蹤而儲存在使用者本地終端上的資料(通常經過加密)。定義於 RFC2109 和 2965 中的都已廢棄,最新取代的規範是 RFC6265[1] 。(可以叫做瀏覽器快取)

簡介:

  • Cookie 是在 HTTP 協議下,伺服器或指令碼可以維護客戶工作站上資訊的一種方式。Cookie 是由 Web 伺服器儲存在使用者瀏覽器(客戶端)上的小文字檔案,它可以包含有關使用者的資訊。無論何時使用者連結到伺服器,Web 站點都可以訪問 Cookie 資訊[2] 。

  • 目前有些 Cookie 是臨時的,有些則是持續的。臨時的 Cookie 只在瀏覽器上儲存一段規定的時間,一旦超過規定的時間,該 Cookie 就會被系統清除[2] 。

  • 持續的 Cookie 則儲存在使用者的 Cookie 檔案中,下一次使用者返回時,仍然可以對它進行呼叫。在 Cookie 檔案中儲存 Cookie,有些使用者擔心 Cookie 中的使用者資訊被一些別有用心的人竊取,而造成一定的損害。其實,網站以外的使用者無法跨過網站來獲得 Cookie 資訊。如果因為這種擔心而遮蔽 Cookie,肯定會因此拒絕訪問許多站點頁面。因為,當今有許多 Web 站點開發人員使用 Cookie 技術,例如 Session 物件的使用就離不開 Cookie 的支援[2] 。

功能:

  • 在同一個頁面中設定 Cookie,實際上是按從後往前的順序進行的。如果要先刪除一個 Cookie,再寫入一個 Cookie,則必須先寫寫入語句,再寫刪除語句,否則會出現錯誤[2] 。

  • Cookie是面向路徑的。預設路徑 (path) 屬性時,Web 伺服器頁會自動傳遞當前路徑給瀏覽器,指定路徑強制伺服器使用設定的路徑。在一個目錄頁面裡設定的 Cookie 在另一個目錄的頁面裡是看不到的 [2] 。

  • Cookie 必須在 HTML 檔案的內容輸出之前設定;不同的瀏覽器 (Netscape Navigator、Internet Explorer) 對 Cookie 的處理不一致,使用時一定要考慮;客戶端使用者如果設定禁止 Cookie,則 Cookie 不能建立。 並且在客戶端,一個瀏覽器能建立的 Cookie 數量最多為 300 個,並且每個不能超過 4KB,每個 Web 站點能設定的 Cookie 總數不能超過 20 個[2] 。

image

image

cookie程式碼示範

<?php
//建立cookie資訊
//將使用者名稱和密碼儲存到客戶端的cookie
//第一個引數表示cookie的一個key,第二個引數表示value,第三個引數表示儲存的時長
setcookie("name","qb",time()+3600);

echo "123";

對如上程式碼解釋:

  • ①、當瀏覽器訪問介面時候,伺服器會以
    Set-Cookie:name=qb; expires=Thu, 15-Jun-2017 10:56:08 GMT 此種類型儲存該cookie到
  • ②、如果我們沒有該時間(第三個引數)cookie不會儲存到本地客戶端,當瀏覽器會話結束,cookie就失效了
  • ③、注意cookie僅僅只能儲存字串
setcookie("lastvisit",date("Y-m-d H:i:s"),time()+3600*2);

if (!empty($_COOKIE)){
	echo "您上次訪問時間為".$_COOKIE['lastvisit'];
}

有可能你在使用顯示上次登入的時間時候會提示一個時區錯誤 因為 php 預設不設定時區。。那麼就只能自己設定了
1、php檔案中設定 (date_default_timezone_set 用這個函式 系統提供的直接在寫程式碼時候設定下)

date_default_timezone_set("Asia/Chongqing");

2、php.ini檔案中設定
image
增加登陸setcookieNameWork1.4.rar
部分示例程式碼

<form method="post" action="LoginProcess.php">
<table border='1px' width='400px'>
	<tr>
		<td>使用者登陸</td>
	</tr>
</table>
<br />
使用者名稱:<input type="text" name='username' value='<?php echo getCookieVal("username")?>' /><br />
密 碼:<input type="password" name='password' value='' /><br />
是否要儲存cookies<input type="checkbox" name="iscookies" value="iscookies"/><br />
<input type="submit" value='提交' /></form>
if (!empty($_POST['iscookies'])){
	echo "使用者需要儲存賬號密碼";
	setcookie("username",$username,time()+3600*7);
}else {
	echo "使用者不需要儲存賬號密碼";
	if (!empty($_COOKIE['username'])){
		setcookie("username",$username,time()-100);
	}
}
function getCookieVal($key){
	if (!empty($_COOKIE[$key])){
		return $_COOKIE[$key];
	}else {
		return "";
	}

}

涉及檔案
login.php;
LoginProcess.php;
Utils.php;
setcookie(“username”,$username);
這樣儲存不設定過期時間的話,不會儲存到本地但是能訪問到生命週期也就是瀏覽器的開關。關了就訪問不到了