主頁 > 知識庫 > PHP的cookie與session原理及用法詳解

PHP的cookie與session原理及用法詳解

熱門標(biāo)簽:阿里云 服務(wù)器配置 電子圍欄 科大訊飛語音識別系統(tǒng) 銀行業(yè)務(wù) 團(tuán)購網(wǎng)站 Linux服務(wù)器 Mysql連接數(shù)設(shè)置

本文實(shí)例講述了PHP的cookie與session原理及用法。分享給大家供大家參考,具體如下:

產(chǎn)生背景

HTTP協(xié)議是無狀態(tài)的協(xié)議。一旦數(shù)據(jù)交換完畢,客戶端與服務(wù)器端的連接就會關(guān)閉,再次交換數(shù)據(jù)需要建立新的連接。這就意味著服務(wù)器無法從連接上跟蹤會話。于是需要引入一種機(jī)制,COOKIE于是就順應(yīng)而生。

Session是另一種記錄客戶狀態(tài)的機(jī)制,不同的是Cookie保存在客戶端瀏覽器中,而Session保存在服務(wù)器上??蛻舳藶g覽器訪問服務(wù)器的時(shí)候,服務(wù)器把客戶端信息以某種形式記錄在服務(wù)器上。這就是Session。

理解例子

以前大學(xué)的時(shí)候,經(jīng)常去大卡司去喝奶茶,每喝一杯,都可以得到一個(gè)印花(第一次喝的時(shí)候他會給你個(gè)積分卡片),集齊6個(gè)印花之后,就可以免費(fèi)獲得一杯奶茶。這樣子,印花的信息是保存在客戶的積分卡上,你如果不懷好意的話,就自己搞幾個(gè)神似的印花去騙奶茶喝吧。哈哈,這樣子是不是更符合在客戶端端(cookie)保持狀態(tài)。而拿銀行卡去銀行取錢,我們的卡只需要保存一個(gè)卡號,更多的信息是保存在服務(wù)器中(session),這樣也比較符合服務(wù)器端保持狀態(tài)。

具體來說cookie機(jī)制采用的是在客戶端保持狀態(tài)的方案,而session機(jī)制采用的是在服務(wù)器端保持狀態(tài)的方案。同時(shí)我們也看到,由于采用服務(wù)器端保持狀態(tài)的方案在客戶端也需要保存一個(gè)標(biāo)識,所以session機(jī)制可能需要借助于cookie機(jī)制來達(dá)到保存標(biāo)識的目的,

簡述cookie

PHP工作原理:PHP通過setcookie函數(shù)進(jìn)行Cookie的設(shè)置,任何從瀏覽器發(fā)回的Cookie,PHP都會自動的將他存儲在$_COOKIE的全局變量之中,因此我們可以通過$_COOKIE['key']的形式來讀取某個(gè)Cookie值。

用途:PHP中的Cookie具有非常廣泛的使用,經(jīng)常用來存儲用戶的登錄信息,購物車等,且在使用會話 Session時(shí)通常使用Cookie來存儲會話id來識別用戶,Cookie具備有效期,當(dāng)有效期結(jié)束之后,Cookie會自動的從客戶端刪除。同時(shí)為 了進(jìn)行安全控制,Cookie還可以設(shè)置域跟路徑。

函數(shù)Cookie

PHP設(shè)置Cookie最常用的方法就是使用setcookie函數(shù),setcookie具有7個(gè)可選參數(shù),我們常用到的為前5個(gè):

  • name( Cookie名)可以通過$_COOKIE['name'] 進(jìn)行訪問
  • value(Cookie的值)
  • expire(過期時(shí)間)Unix時(shí)間戳格式,默認(rèn)為0,表示瀏覽器關(guān)閉即失效
  • path(有效路徑)如果路徑設(shè)置為'/',則整個(gè)網(wǎng)站都有效
  • domain(有效域)默認(rèn)整個(gè)域名都有效,如果設(shè)置了'www.imooc.com',則只在www子域中有效
$value = 'test';
setcookie("TestCookie", $value);
setcookie("TestCookie", $value, time()+3600); //有效期一小時(shí)
setcookie("TestCookie", $value, time()+3600, "/path/", "imooc.com"); //設(shè)置路徑與域

PHP中還有一個(gè)設(shè)置Cookie的函數(shù)setrawcookie,setrawcookie跟setcookie基本一樣,唯一的不同就是value值不會自動的進(jìn)行urlencode,因此在需要的時(shí)候要手動的進(jìn)行urlencode。

setrawcookie('cookie_name', rawurlencode($value), time()+606024*365);

因?yàn)镃ookie是通過HTTP標(biāo)頭進(jìn)行設(shè)置的,所以也可以直接使用header方法進(jìn)行設(shè)置。

header("Set-Cookie:cookie_name=value");

刪除cookie

PHP設(shè)置Cookie最常用的方法就是使用setcookie函數(shù),setcookie具有7個(gè)可選參數(shù),我們常用到的為前5個(gè):

  • name( Cookie名)可以通過$_COOKIE['name'] 進(jìn)行訪問
  • value(Cookie的值)
  • expire(過期時(shí)間)Unix時(shí)間戳格式,默認(rèn)為0,表示瀏覽器關(guān)閉即失效
  • path(有效路徑)如果路徑設(shè)置為'/',則整個(gè)網(wǎng)站都有效
  • domain(有效域)默認(rèn)整個(gè)域名都有效,如果設(shè)置了'www.imooc.com',則只在www子域中有效
$value = 'test';
setcookie("TestCookie", $value);
setcookie("TestCookie", $value, time()+3600); //有效期一小時(shí)
setcookie("TestCookie", $value, time()+3600, "/path/", "imooc.com"); //設(shè)置路徑與域

PHP中還有一個(gè)設(shè)置Cookie的函數(shù)setrawcookie,setrawcookie跟setcookie基本一樣,唯一的不同就是value值不會自動的進(jìn)行urlencode,因此在需要的時(shí)候要手動的進(jìn)行urlencode。

setrawcookie('cookie_name', rawurlencode($value), time()+606024*365);

因?yàn)镃ookie是通過HTTP標(biāo)頭進(jìn)行設(shè)置的,所以也可以直接使用header方法進(jìn)行設(shè)置。

header("Set-Cookie:cookie_name=value");

簡述session

在PHP中使用session非常簡單,先執(zhí)行session_start方法開啟session,然后通過全局變量$_SESSION進(jìn)行session的讀寫。

session_start();
$_SESSION['test'] = time();
var_dump($_SESSION);

刪除session

在PHP中使用session非常簡單,先執(zhí)行session_start方法開啟session,然后通過全局變量$_SESSION進(jìn)行session的讀寫。

session_start();
$_SESSION['test'] = time();
var_dump($_SESSION);

session會自動的對要設(shè)置的值進(jìn)行encode與decode,因此session可以支持任意數(shù)據(jù)類型,包括數(shù)據(jù)與對象等。

session_start();
$_SESSION['ary'] = array('name' => 'jobs');
$_SESSION['obj'] = new stdClass();
var_dump($_SESSION);

默認(rèn)情況下,session是以文件形式存儲在服務(wù)器上的,因此當(dāng)一個(gè)頁面開啟了session之后,會獨(dú)占這個(gè)session文件,這樣會導(dǎo)致當(dāng)前用戶的其他并發(fā)訪問無法執(zhí)行而等待??梢圆捎镁彺婊蛘邤?shù)據(jù)庫的形式存儲來解決這個(gè)問題,這個(gè)我們會在一些高級的課程中講到。

session存儲用戶信息

session可以用來存儲多種類型的數(shù)據(jù),因此具有很多的用途,常用來存儲用戶的登錄信息,購物車數(shù)據(jù),或者一些臨時(shí)使用的暫存數(shù)據(jù)等。
用戶在登錄成功以后,通??梢詫⒂脩舻男畔⒋鎯υ趕ession中,一般的會單獨(dú)的將一些重要的字段單獨(dú)存儲,然后所有的用戶信息獨(dú)立存儲。

$_SESSION['uid'] = $userinfo['uid'];
$_SESSION['userinfo'] = $userinfo;

一般來說,登錄信息既可以存儲在sessioin中,也可以存儲在cookie中,他們之間的差別在于session可以方便的存取多種數(shù)據(jù)類型, 而cookie只支持字符串類型,同時(shí)對于一些安全性比較高的數(shù)據(jù),cookie需要進(jìn)行格式化與加密存儲,而session存儲在服務(wù)端則安全性較高。

?php
session_start();//假設(shè)用戶登錄成功獲得了以下用戶數(shù)據(jù)
$userinfo = array(
  'uid' => 10000,
  'name' => 'spark',
  'email' => 'spark@imooc.com',
  'sex' => 'man',
  'age' => '18');
header("content-type:text/html; charset=utf-8");
/* 將用戶信息保存到session中 */
$_SESSION['uid'] = $userinfo['uid'];
$_SESSION['name'] = $userinfo['name'];
$_SESSION['userinfo'] = $userinfo;
//* 將用戶數(shù)據(jù)保存到cookie中的一個(gè)簡單方法 */
$secureKey = 'imooc'; //加密密鑰
$str = serialize($userinfo); //將用戶信息序列化//用戶信息加密前
$str = base64_encode(mcrypt_encrypt(MCRYPT_RIJNDAEL_256, md5($secureKey), $str, MCRYPT_MODE_ECB));//用戶信息加密后//將加密后的用戶數(shù)據(jù)存儲到cookie中
setcookie('userinfo', $str);
//當(dāng)需要使用時(shí)進(jìn)行解密
$str = mcrypt_decrypt(MCRYPT_RIJNDAEL_256, md5($secureKey), base64_decode($str), MCRYPT_MODE_ECB);
$uinfo = unserialize($str);
echo "解密后的用戶信息:br>";
print_r($uinfo);

異同

1.cookie將數(shù)據(jù)存儲在客戶端,建立起用戶與服務(wù)器之間的聯(lián)系,session是將用戶的會話數(shù)據(jù)存儲在服務(wù)端
2.cookie相對不是太安全,容易被盜用導(dǎo)致cookie欺騙
3.單個(gè)cookie的值最大只能存儲4k  session沒有大小限制
4.每次請求都要進(jìn)行網(wǎng)絡(luò)傳輸,占用帶寬
5.通過一個(gè)session_id進(jìn)行用戶識別,PHP默認(rèn)情況下session id是通過cookie來保存的,因此從某種程度上來說,seesion依賴于cookie。但這不是絕對的,session id也可以通過參數(shù)來實(shí)現(xiàn),只要能將session id傳遞到服務(wù)端進(jìn)行識別的機(jī)制都可以使用session。

jQuery Cookie 插件

引入

script src="https://cdn.staticfile.org/jquery/3.4.0/jquery.min.js">/script> 
script src="https://cdn.staticfile.org/jquery-cookie/1.4.1/jquery.cookie.min.js">/script>

設(shè)置刪除

$.cookie('name', 'value', { expires: 7, path: '/' });
$.removeCookie('name'); // => true

更多關(guān)于PHP相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《PHP中cookie用法總結(jié)》、《php緩存技術(shù)總結(jié)》、《PHP數(shù)組(Array)操作技巧大全》、《PHP網(wǎng)絡(luò)編程技巧總結(jié)》及《php字符串(string)用法總結(jié)》

希望本文所述對大家PHP程序設(shè)計(jì)有所幫助。

您可能感興趣的文章:
  • PHP實(shí)現(xiàn)cookie跨域session共享的方法分析
  • PHP+Apache實(shí)現(xiàn)二級域名之間共享cookie的方法
  • PHP cookie,session的使用與用戶自動登錄功能實(shí)現(xiàn)方法分析
  • PHP CURL中傳遞cookie的方法步驟
  • php更新cookie內(nèi)容的詳細(xì)方法

標(biāo)簽:衡水 棗莊 衢州 大理 江蘇 蚌埠 廣元 萍鄉(xiāng)

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《PHP的cookie與session原理及用法詳解》,本文關(guān)鍵詞  ;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 收縮
    • 微信客服
    • 微信二維碼
    • 電話咨詢

    • 400-1100-266