真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

PHP中session會話操作技巧有哪些-創(chuàng)新互聯(lián)

這篇文章主要介紹PHP中session會話操作技巧有哪些,文中介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們一定要看完!

員工經(jīng)過長期磨合與沉淀,具備了協(xié)作精神,得以通過團隊的力量開發(fā)出優(yōu)質(zhì)的產(chǎn)品。創(chuàng)新互聯(lián)堅持“專注、創(chuàng)新、易用”的產(chǎn)品理念,因為“專注所以專業(yè)、創(chuàng)新互聯(lián)網(wǎng)站所以易用所以簡單”。公司專注于為企業(yè)提供做網(wǎng)站、網(wǎng)站設(shè)計、微信公眾號開發(fā)、電商網(wǎng)站開發(fā),微信小程序,軟件定制設(shè)計等一站式互聯(lián)網(wǎng)企業(yè)服務(wù)。

具體如下:

會話技術(shù)

session

將會話數(shù)據(jù)存儲與服務(wù)器端,同時使會話數(shù)據(jù)可以區(qū)分瀏覽器
為每個會話數(shù)據(jù)建立獨立的會話數(shù)據(jù)區(qū)(來存儲當前會話的全部數(shù)據(jù)),每個會話數(shù)據(jù)區(qū)存在的標志,同時瀏覽器端存儲該標識配對使用。
響應(yīng)時給瀏覽器的session-id值也存儲于瀏覽器端的cookie數(shù)據(jù)區(qū)。

php.ini:

session.auto_start = 0

session_start();

增刪改查都是使用$_SESSION完成
跟操作普通數(shù)組一樣操作$_SESSION數(shù)組,就可以完成對session數(shù)據(jù)的操作

session原理

存儲于瀏覽器端cookie中的session-id,就是一個普通的cookie變量

 PHP中session會話操作技巧有哪些

每個會話生成存儲于服務(wù)器端的session數(shù)據(jù)區(qū)

默認的以文件的形式存儲于服務(wù)器系統(tǒng)臨時目錄下

session.save_path = '/temp'

session數(shù)據(jù)屬性

有效期:一個會話周期

有效路徑:整站

有效域:當前域

是否僅安全連接傳輸:否

是否HTTPOnly:否

以上session數(shù)據(jù)的特征,都是由瀏覽器cookie中存儲的session-id的特征所導(dǎo)致的。可見如果需要改變session數(shù)據(jù)的屬性,則需更改存儲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 =

如果需要對默認屬性進行修改,可通過以下方法:

1. 修改php.ini配置文件;

2. 在腳本中使用 ini_set(key,val) 進行設(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語法問題

session數(shù)據(jù)可以是任意的類型,因為session數(shù)據(jù)區(qū)的數(shù)據(jù)就是序列化后存儲的。

$_SESSION['']的下標只能是字符串

session_start()前不應(yīng)存在輸出

session數(shù)據(jù)區(qū)

在腳本周期外,持久存儲當前會話session數(shù)據(jù)

在腳本周期內(nèi),使用$_SESSION管理session數(shù)據(jù)

session 銷毀

//刪除當前會話對應(yīng)的session數(shù)據(jù)區(qū)并關(guān)閉session機制(周期結(jié)束后無法持久化)
session_destroy();
//$_SESSION還是存在的

清空session數(shù)據(jù)

$_SESSION = array();

當前相關(guān)session的全部數(shù)據(jù)刪除:

session_destroy();
unset($_SESSION);
setcookie('PHPSESSID',"",time()-1);
//PHPSESSID稱之為session.name 可通過php.ini配置
//可通過session_name()獲取當前值
; Name of the session (used as cookie name).
; http://php.net/session.name
session.name = PHPSESSID

重寫session存儲機制(入庫、入內(nèi)存)

目的:

便于管理大量session數(shù)據(jù)
便于web服務(wù)器集群共享session數(shù)據(jù)

實現(xiàn):

定義自定義的相關(guān)的存儲處理函數(shù)
將其設(shè)置為session機制需要的存儲函數(shù)(告知session機制,使用我們的函數(shù)完成存儲處理)

session機制:

session_set_save_handler();

共需六個存儲處理函數(shù)

begin、end、read、write、del、gc(垃圾回收)

需要在session_start()前使用

';
 $link = mysql_connect('127.0.0.1','root','root');
 mysql_query('set names utf8');
 mysql_select_db('session_override');
}
//在session機制關(guān)閉時執(zhí)行的方法,最后一個執(zhí)行的存儲相關(guān)操作,用于收尾
function ses_end(){
 echo 'end
';  return true; } //不需要負責反序列化操作,在讀取之后腳本自動執(zhí)行 function ses_read($ses_id){ // echo 'read
';  $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 '';  } } //不需要序列化操作,在寫入之前腳本會自動執(zhí)行 function ses_write($ses_id,$ses_con){ // echo 'write
'; // echo $ses_id,$ses_con;  $sql = "replace into session values( '$ses_id' , '$ses_con',unix_timestamp() )";  echo $sql.'
';  return mysql_query($sql); } //當調(diào)用session_destroy()時執(zhí)行 function ses_del($ses_id){ // echo 'del
';  $sql = "delete from session where session_id = '$ses_id'";  return mysql_query($sql); } //session.gc_maxlifetime = 1440 //在開啟session機制的過程中,有概率地執(zhí)行垃圾回收機制 //session.gc_probability = 1 //session.gc_divisor = 1000 //@param session.gc_maxlifetime //return boolean function ses_gc($maxlifetime){ // echo 'gc
';  ini_set('session.gc_divisor',2);  $sql = 'delete from session_override where last_time

session 與 cookie

聯(lián)系

都是會話技術(shù)的實現(xiàn)
session基于cookie

差異

Tablescookiesession
會話數(shù)據(jù)存儲位置瀏覽器端服務(wù)器端
安全性
數(shù)據(jù)傳輸量
支持會話數(shù)據(jù)量有限制 4K 20個無大小限制
支持數(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ù)上可以通過get或者post方式向服務(wù)器攜帶session-id

//是否僅僅使用cookie攜帶session-id
ini_set('session.use_only_cookies','0');
//是否自動采用其它方式自動傳session-id,不安全
ini_set('session.use_trans_sid','1');

以上是“PHP中session會話操作技巧有哪些”這篇文章的所有內(nèi)容,感謝各位的閱讀!希望分享的內(nèi)容對大家有幫助,更多相關(guān)知識,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!


本文標題:PHP中session會話操作技巧有哪些-創(chuàng)新互聯(lián)
分享URL:http://weahome.cn/article/djposh.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部