PHP session會(huì)話操作技巧小結(jié)
本文實(shí)例總結(jié)了PHP session會(huì)話操作技巧。分享給大家供大家參考,具體如下:
會(huì)話技術(shù)
session
將會(huì)話數(shù)據(jù)存儲(chǔ)與服務(wù)器端,同時(shí)使會(huì)話數(shù)據(jù)可以區(qū)分瀏覽器
為每個(gè)會(huì)話數(shù)據(jù)建立獨(dú)立的會(huì)話數(shù)據(jù)區(qū)(來(lái)存儲(chǔ)當(dāng)前會(huì)話的全部數(shù)據(jù)),每個(gè)會(huì)話數(shù)據(jù)區(qū)存在唯一的標(biāo)志,同時(shí)瀏覽器端存儲(chǔ)該唯一標(biāo)識(shí)配對(duì)使用。
響應(yīng)時(shí)給瀏覽器的session-id值也存儲(chǔ)于瀏覽器端的cookie數(shù)據(jù)區(qū)。
php.ini:
session.auto_start = 0
session_start();
增刪改查都是使用$_SESSION完成
跟操作普通數(shù)組一樣操作$_SESSION數(shù)組,就可以完成對(duì)session數(shù)據(jù)的操作
session原理
存儲(chǔ)于瀏覽器端cookie中的session-id,就是一個(gè)普通的cookie變量
每個(gè)會(huì)話生成存儲(chǔ)于服務(wù)器端的session數(shù)據(jù)區(qū)
默認(rèn)的以文件的形式存儲(chǔ)于服務(wù)器系統(tǒng)臨時(shí)目錄下
session.save_path = '/temp'
session數(shù)據(jù)屬性
有效期:一個(gè)會(huì)話周期
有效路徑:整站
有效域:當(dāng)前域
是否僅安全連接傳輸:否
是否HTTPOnly:否
以上session數(shù)據(jù)的特征,都是由瀏覽器cookie中存儲(chǔ)的session-id的特征所導(dǎo)致的??梢?jiàn)如果需要改變session數(shù)據(jù)的屬性,則需更改存儲(chǔ)session-id的cookie變量PHPSESSID的屬性:
php.ini 存在該屬性的設(shè)置:
僅安全連接傳輸:
; http://php.net/session.cookie-secure ;session.cookie_secure =
生命周期:
; Lifetime in seconds of cookie or, if 0, until browser is restarted. ; http://php.net/session.cookie-lifetime session.cookie_lifetime = 0
有效路徑:
; The path for which the cookie is valid. ; http://php.net/session.cookie-path session.cookie_path = /
有效域:
; The domain for which the cookie is valid. ; http://php.net/session.cookie-domain session.cookie_domain =
HTTPOnly:
; Whether or not to add the httpOnly flag to the cookie, which makes it inaccessible to browser scripting languages such as JavaScript. ; http://php.net/session.cookie-httponly session.cookie_httponly =
如果需要對(duì)默認(rèn)屬性進(jìn)行修改,可通過(guò)以下方法:
1. 修改php.ini配置文件;
2. 在腳本中使用 ini_set(key,val) 進(jìn)行設(shè)置配置的修改,僅在設(shè)置后的腳本周期內(nèi)有效,要在 session_start() 前設(shè)置完畢;
3. 使用特定功能函數(shù):
//session_set_cookie_params(有效期,有效路徑,有效域,是否僅安全傳輸連接,是否HTTPOnly); session_set_cookie_paramas(60,'/','me.com',true,true); session_start();
session語(yǔ)法問(wèn)題
session數(shù)據(jù)可以是任意的類型,因?yàn)閟ession數(shù)據(jù)區(qū)的數(shù)據(jù)就是序列化后存儲(chǔ)的。
$_SESSION['']的下標(biāo)只能是字符串
session_start()前不應(yīng)存在輸出
session數(shù)據(jù)區(qū)
在腳本周期外,持久存儲(chǔ)當(dāng)前會(huì)話session數(shù)據(jù)
在腳本周期內(nèi),使用$_SESSION管理session數(shù)據(jù)
session 銷毀
//刪除當(dāng)前會(huì)話對(duì)應(yīng)的session數(shù)據(jù)區(qū)并關(guān)閉session機(jī)制(周期結(jié)束后無(wú)法持久化) session_destroy(); //$_SESSION還是存在的
清空session數(shù)據(jù)
$_SESSION = array();
當(dāng)前相關(guān)session的全部數(shù)據(jù)刪除:
session_destroy(); unset($_SESSION); setcookie('PHPSESSID',"",time()-1); //PHPSESSID稱之為session.name 可通過(guò)php.ini配置 //可通過(guò)session_name()獲取當(dāng)前值 ; Name of the session (used as cookie name). ; http://php.net/session.name session.name = PHPSESSID
重寫(xiě)session存儲(chǔ)機(jī)制(入庫(kù)、入內(nèi)存)
目的:
便于管理大量session數(shù)據(jù)
便于web服務(wù)器集群共享session數(shù)據(jù)
實(shí)現(xiàn):
定義自定義的相關(guān)的存儲(chǔ)處理函數(shù)
將其設(shè)置為session機(jī)制需要的存儲(chǔ)函數(shù)(告知session機(jī)制,使用我們的函數(shù)完成存儲(chǔ)處理)
session機(jī)制:
session_set_save_handler();
共需六個(gè)存儲(chǔ)處理函數(shù)
begin、end、read、write、del、gc(垃圾回收)
需要在session_start()前使用
<?php //session 開(kāi)始執(zhí)行時(shí)最早執(zhí)行的一個(gè)存儲(chǔ)相關(guān)方法,用于初始化存儲(chǔ)操作的相關(guān)資源 function ses_beg(){ // echo 'begin</br>'; $link = mysql_connect('127.0.0.1','root','root'); mysql_query('set names utf8'); mysql_select_db('session_override'); } //在session機(jī)制關(guān)閉時(shí)執(zhí)行的方法,最后一個(gè)執(zhí)行的存儲(chǔ)相關(guān)操作,用于收尾 function ses_end(){ echo 'end</br>'; return true; } //不需要負(fù)責(zé)反序列化操作,在讀取之后腳本自動(dòng)執(zhí)行 function ses_read($ses_id){ // echo 'read</br>'; $sql = "select session_content from session where session_id = '$ses_id'"; $res = mysql_query($sql); if($row = mysql_fetch_assoc($res)){ return $row['session_content']; }else{ return ''; } } //不需要序列化操作,在寫(xiě)入之前腳本會(huì)自動(dòng)執(zhí)行 function ses_write($ses_id,$ses_con){ // echo 'write</br>'; // echo $ses_id,$ses_con; $sql = "replace into session values( '$ses_id' , '$ses_con',unix_timestamp() )"; echo $sql.'</br>'; return mysql_query($sql); } //當(dāng)調(diào)用session_destroy()時(shí)執(zhí)行 function ses_del($ses_id){ // echo 'del</br>'; $sql = "delete from session where session_id = '$ses_id'"; return mysql_query($sql); } //session.gc_maxlifetime = 1440 //在開(kāi)啟session機(jī)制的過(guò)程中,有概率地執(zhí)行垃圾回收機(jī)制 //session.gc_probability = 1 //session.gc_divisor = 1000 //@param session.gc_maxlifetime //return boolean function ses_gc($maxlifetime){ // echo 'gc</br>'; ini_set('session.gc_divisor',2); $sql = 'delete from session_override where last_time<unix_timestamp()-'.$maxlifetime; return mysql_query($sql); } //filesPHP內(nèi)置的session存儲(chǔ)處理器 //重寫(xiě)session機(jī)制,應(yīng)該改為user用戶自定義 ini_set('session.save_handler','user'); //配置存儲(chǔ)機(jī)制要在start之前,要保證session不自動(dòng)開(kāi)啟 //session.auto_start=0 //.htacess php_flag session.auto_start 0 session_set_save_handler('ses_beg','ses_end','ses_read','ses_write','ses_del','ses_gc'); session_start(); $_SESSION['id'] = 'test'; session_destroy();
session 與 cookie
聯(lián)系
都是會(huì)話技術(shù)的實(shí)現(xiàn)
session基于cookie
差異
Tables | cookie | session |
---|---|---|
會(huì)話數(shù)據(jù)存儲(chǔ)位置 | 瀏覽器端 | 服務(wù)器端 |
安全性 | 低 | 高 |
數(shù)據(jù)傳輸量 | 大 | 小 |
支持會(huì)話數(shù)據(jù)量 | 有限制 4K 20個(gè) | 無(wú)大小限制 |
支持?jǐn)?shù)據(jù)類型 | 字符串 | ALL |
session數(shù)據(jù)持久化
瀏覽器端 session-id
session_set_params(3600)
服務(wù)器端 session數(shù)據(jù)區(qū)
ini_set('session.gc_maxlifetime','3600')
cookie禁用
常規(guī)情況下,cookie禁用,session不能使用
技術(shù)上可以通過(guò)get或者post方式向服務(wù)器攜帶session-id
//是否僅僅使用cookie攜帶session-id ini_set('session.use_only_cookies','0'); //是否自動(dòng)采用其它方式自動(dòng)傳session-id,不安全 ini_set('session.use_trans_sid','1');
更多關(guān)于PHP相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《PHP中cookie用法總結(jié)》、《PHP數(shù)組(Array)操作技巧大全》、《PHP基本語(yǔ)法入門教程》、《PHP運(yùn)算與運(yùn)算符用法總結(jié)》、《php面向?qū)ο蟪绦蛟O(shè)計(jì)入門教程》、《PHP網(wǎng)絡(luò)編程技巧總結(jié)》、《php字符串(string)用法總結(jié)》、《php+mysql數(shù)據(jù)庫(kù)操作入門教程》及《php常見(jiàn)數(shù)據(jù)庫(kù)操作技巧匯總》
希望本文所述對(duì)大家PHP程序設(shè)計(jì)有所幫助。
相關(guān)文章
php計(jì)數(shù)排序算法的實(shí)現(xiàn)代碼(附四個(gè)實(shí)例代碼)
計(jì)數(shù)排序(Counting sort)是一種根據(jù)小整數(shù)鍵對(duì)一組對(duì)象排序的算法;也就是說(shuō),它是一個(gè)整數(shù)排序算法。它通過(guò)計(jì)算具有不同鍵值的對(duì)象的數(shù)量,并對(duì)這些數(shù)量使用算術(shù)來(lái)確定輸出序列中每個(gè)鍵值的位置2020-03-03WordPress的主題編寫(xiě)中獲取頭部模板和底部模板
這篇文章主要介紹了WordPress的主題編寫(xiě)中獲取頭部模板和底部模板的技巧,分別是get_header()與get_footer()函數(shù)的使用,需要的朋友可以參考下2015-12-12php常用字符串長(zhǎng)度函數(shù)strlen()與mb_strlen()用法實(shí)例分析
這篇文章主要介紹了php常用字符串長(zhǎng)度函數(shù)strlen()與mb_strlen()用法,結(jié)合實(shí)例形式分析了php字符串長(zhǎng)度函數(shù)strlen()與mb_strlen()功能、用法及相關(guān)操作注意事項(xiàng),需要的朋友可以參考下2019-06-06PHP設(shè)計(jì)模式之委托模式定義與用法簡(jiǎn)單示例
這篇文章主要介紹了PHP設(shè)計(jì)模式之委托模式定義與用法,簡(jiǎn)單描述了委托模式的功能、定義與簡(jiǎn)單使用方法,需要的朋友可以參考下2018-08-08PHP實(shí)現(xiàn)多維數(shù)組轉(zhuǎn)字符串和多維數(shù)組轉(zhuǎn)一維數(shù)組的方法
這篇文章主要介紹了PHP實(shí)現(xiàn)多維數(shù)組轉(zhuǎn)字符串和多維數(shù)組轉(zhuǎn)一維數(shù)組的方法,以實(shí)例形式分別介紹了php數(shù)組與字符串的轉(zhuǎn)換技巧,非常簡(jiǎn)單實(shí)用,需要的朋友可以參考下2015-08-08搭建基于Docker的PHP開(kāi)發(fā)環(huán)境的詳細(xì)教程
這篇文章主要介紹了搭建基于Docker的PHP開(kāi)發(fā)環(huán)境的詳細(xì)教程,Docker是當(dāng)下虛擬機(jī)技術(shù)的最佳選擇,需要的朋友可以參考下2015-07-07