php中session的基礎(chǔ)知識(shí)_第1頁(yè)
php中session的基礎(chǔ)知識(shí)_第2頁(yè)
php中session的基礎(chǔ)知識(shí)_第3頁(yè)
php中session的基礎(chǔ)知識(shí)_第4頁(yè)
php中session的基礎(chǔ)知識(shí)_第5頁(yè)
已閱讀5頁(yè),還剩3頁(yè)未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(quán)說(shuō)明:本文檔由用戶(hù)提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡(jiǎn)介

本文格式為Word版,下載可任意編輯——php中session的基礎(chǔ)知識(shí)PHP是一種通用開(kāi)源腳本語(yǔ)言。下面是我整理的php中session的根基學(xué)識(shí),夢(mèng)想對(duì)大家有扶助!

session的生命周期是多長(zhǎng)

1欣賞器終止時(shí)其生命周期也同時(shí)終止,但是檔案依舊存在于/tmp/sess_???

2下次重新開(kāi)欣賞器時(shí)會(huì)重新調(diào)配sessionID,假設(shè)你使用session_id把以前的ID帶回來(lái),那么會(huì)去讀取殘存在/tmp處的sess_???,取回你之前全體已經(jīng)設(shè)定的參數(shù)

3可以在PHP.ini里修改session檔案殘存的時(shí)間

session.gc_maxlifetime=1440;afterthisnumberofseconds,stored

datawillbeseenasgarbageand

cleanedupbythegcprocess

默認(rèn)是1440秒,24分鐘

使用session留神的存儲(chǔ)路徑問(wèn)題,看看php.ini里對(duì)于session的設(shè)置

[Session]

session.save_handler=files;handlerusedtostore/retrievedata

session.save_path=/tmp;argumentpassedtosave_handler

inthecaseoffiles,thisisthe

pathwheredatafilesarestored

默認(rèn)是存于/tmp目次下,這個(gè)目次可不確定真有啊,最好改為你的php安裝路徑,譬如c:/php

徹底理解PHP的SESSION機(jī)制

1.session.save_handler=files

*1.session_start

1.session_start是session機(jī)制的開(kāi)頭,它有確定概率開(kāi)啟垃圾回收,由于session是存放在文件中,

PHP自身的垃圾回收是無(wú)效的,SESSION的回收是要?jiǎng)h文件的,這個(gè)概率是根據(jù)php.ini的配置抉擇的,

但是有的系統(tǒng)是session.gc_probability=0,這也就是說(shuō)概率是0,而是通過(guò)cron腳本來(lái)實(shí)現(xiàn)垃圾回收.

session.gc_probability=1

session.gc_pisor=1000

session.gc_maxlifetime=1440//過(guò)期時(shí)間默認(rèn)24分鐘

//概率是session.gc_probability/session.gc_pisor結(jié)果1/1000,

//不建議設(shè)置過(guò)小,由于session的垃圾回收,是需要檢查每個(gè)文件是否過(guò)期的。

session.save_path=//猶如不同的系統(tǒng)默認(rèn)不一樣,有一種設(shè)置是N;/path

//這是隨機(jī)分級(jí)存儲(chǔ),這個(gè)樣的話(huà),垃圾回收將不起作用,需要自己寫(xiě)腳本

2.session會(huì)判斷當(dāng)前是否有$_COOKIE[session_name];session_name返回保存session_id的COOKIE鍵值,這個(gè)值可以從php.ini找到

=PHPSESSID//默認(rèn)值PHPSESSID

3.假設(shè)不存在會(huì)生成一個(gè)session_id,然后把生成的session_id作為COOKIE的值傳遞到客戶(hù)端.相當(dāng)于執(zhí)行了下面COOKIE操作,留神的是,這一步執(zhí)行了setcookie操作,COOKIE是在header頭中發(fā)送的,這之前是不能有輸出的,PHP有另外一個(gè)函數(shù)session_regenerate_id假設(shè)使用這個(gè)函數(shù),這之前也是不能有輸出的。

setcookiesession_name,

session_id,

session.cookie_lifetime,//默認(rèn)0

session.cookie_path,//默認(rèn)/當(dāng)前程序跟目次下都有效

session.cookie_domain,//默認(rèn)為空

4.假設(shè)存在那么session_id=$_COOKIE[session_name];

然后去session.save_path指定的文件夾里去找名字為SESS_.session_id的文件.

讀取文件的內(nèi)容反序列化,然后放到$_SESSION中

*2.為$_SESSION賦值

譬如新添加一個(gè)值$_SESSION[test]=blah;那么這個(gè)$_SESSION只會(huì)維護(hù)在內(nèi)存中,當(dāng)腳本執(zhí)行終止的時(shí)候,用把$_SESSION的值寫(xiě)入到session_id指定的文件夾中,然后關(guān)閉相關(guān)資源.這個(gè)階段有可能執(zhí)行更改session_id的操作,譬如銷(xiāo)毀一個(gè)舊的的session_id,生成一個(gè)全新的session_id.一半用在自定義session操作,角色的轉(zhuǎn)換上,譬如Drupal.Drupal的匿名用戶(hù)有一個(gè)SESSION的,當(dāng)它登錄后需要換用新的session_id

ifisset$_COOKIE[session_name]

setcookiesession_name,,time-42000,/;//舊sessioncookie過(guò)期

session_regenerate_id;//這一步會(huì)生成新的session_id

//session_id返回的是新的值

*3.寫(xiě)入SESSION操作

在腳本終止的時(shí)候會(huì)執(zhí)行SESSION寫(xiě)入操作,把$_SESSION中值寫(xiě)入到session_id命名的文件中,可能已經(jīng)存在,可能需要?jiǎng)?chuàng)造新的文件。

*4.銷(xiāo)毀SESSION

SESSION發(fā)出去的COOKIE一般屬于即時(shí)COOKIE,保存在內(nèi)存中,當(dāng)欣賞器關(guān)閉后,才會(huì)過(guò)期,假使需要人為強(qiáng)制過(guò)期,譬如退出登錄,而不是關(guān)閉欣賞器,那么就需要在代碼里銷(xiāo)毀SESSION,方法有好多:

o1.setcookiesession_name,session_id,time-8000000,..;//退出登錄前執(zhí)行

o2.usset$_SESSION;//這會(huì)刪除全體的$_SESSION數(shù)據(jù),刷新后,有COOKIE傳過(guò)來(lái),但是沒(méi)有數(shù)據(jù)。

o3.session_destroy;//這個(gè)作用更徹底,刪除$_SESSION刪除session文件,和session_id

當(dāng)不關(guān)閉欣賞器的處境下,再次刷新,2和3都會(huì)有COOKIE傳過(guò)來(lái),但是找不到數(shù)據(jù)

2.session.save_handler=user

用戶(hù)自定義session處理機(jī)制,更加直觀(guān)

*session_set_save_handleropen,close,read,write,destroy,gc;

1.session_start,執(zhí)行open$save_path,$session_name開(kāi)啟session操作句柄

$save_path在session.save_handler=files的處境下它就是session.save_path,

但是假設(shè)用戶(hù)自定的話(huà),這個(gè)兩個(gè)參數(shù)都用不上,直接返回TRUE,執(zhí)行read$id從中讀取數(shù)據(jù).//這個(gè)參數(shù)是自動(dòng)傳遞的就是session_id,可以通過(guò)這個(gè)值舉行操作。

*2.腳本執(zhí)行終止

執(zhí)行write$id,$sess_data//兩個(gè)參數(shù),很簡(jiǎn)樸

*3.假使用戶(hù)需要session_destroy

先執(zhí)行destroy.在執(zhí)行第2步

一個(gè)實(shí)際例子,代碼如下:

//SESSION初始化的時(shí)候調(diào)用

functionopen$save_path,$session_name

global$sess_save_path;

$sess_save_path=$save_path;

returntrue;

//關(guān)閉的時(shí)候調(diào)用

functionclose

returntrue;

functionread$id

global$sess_save_path;

$sess_file=$sess_save_path/sess_$id;

returnstring@file_get_contents$sess_file;

//腳本執(zhí)行終止之前,執(zhí)行寫(xiě)入操作

functionwrite$id,$sess_data

echosdfsf;

global$sess_save_path;

$sess_file=$sess_save_path/sess_$id;

if$fp=@fopen$sess_file,w

$return=fwrite$fp,$sess_data;

fclose$fp;

return$return;

else

returnfalse;

functiondestroy$id

global$sess_save_path;

$sess_file=$sess_save_path/sess_$id;

return@unlink$sess_file;

functiongc$maxlifetime

global$sess_save_path;

foreachglob$sess_save_path/sess_*as$filename

iffilemtime$filename+$maxlifetimetime

@unlink$filename;

returntrue;

例:PHPSession在您把用戶(hù)信息存儲(chǔ)到PHPsession中之前,首先務(wù)必啟動(dòng)會(huì)話(huà)。

解釋:session_start函數(shù)務(wù)必位于標(biāo)簽之前,代碼如下:

?

phpsession_start;?

上面的代碼會(huì)向服務(wù)器注冊(cè)用戶(hù)的會(huì)話(huà),以便您可以開(kāi)頭保存用戶(hù)信息,同時(shí)會(huì)為用戶(hù)會(huì)話(huà)調(diào)配一個(gè)UID。

存儲(chǔ)Session變量

存儲(chǔ)和取回session

溫馨提示

  • 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶(hù)所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶(hù)上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶(hù)上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶(hù)因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。

最新文檔

評(píng)論

0/150

提交評(píng)論