php session的應用詳細介紹
php session高級應用
session在web技術(shù)中非常重要,由于網(wǎng)頁是一種無狀態(tài)的連接程序,因此無法得知用戶的瀏覽狀態(tài)。通過session則可以記錄用戶的有關(guān)信息,以供用戶再次以此身份對web服務器提交要求時確認。
例如:用戶在瀏覽電子商務網(wǎng)站的時候,如果沒有session,那么用戶每次瀏覽就需要輸入賬戶密碼。
1,Session 臨時文件
在服務器中,如果將用戶所有的Session都保存到臨時目錄中,會降低服務器的安全性和效率。打開服務器存儲的站點會非常的慢。
使用PHP函數(shù)session_save_path()函數(shù)存儲Session臨時文件,可以緩解因臨時文件的存儲導致的服務器效率降低和站點打開緩慢的問題。
示例代碼如下:
<?php $path ="./tmp/"; //設(shè)置session存儲的路徑 session_save_path($path); session_start(); $_SESSION['userName']=true; ?>
注意
session_save_path() 必須在session_start() 之前執(zhí)行。
2,Session 緩存
Session 緩存是將網(wǎng)頁中的內(nèi)容臨時存儲到IE客戶端的Temporary INternet Files文件夾,并且可以設(shè)置緩存的時間。
Session的緩存使用的是 session_cache_limiter()函數(shù),其語法如下:
string session_cache_limiter([string cache_limiter]);
其中參數(shù)cache_limiter 為public 或private 。同事session不是在服務器端,而是在客戶端。在服務器中沒有顯示。
緩存時間的設(shè)置,使用的是函數(shù) session_cache_expire()語法如下:
int session_cache_expire([int new_cahche_expire]);
參數(shù)new_cahche_expire 是session緩存的時間數(shù)字,單位分鐘。
注意:
這兩個session函數(shù)必須在session_start()函數(shù)之前執(zhí)行
session 緩存頁面的示例代碼如下:
<?php
session_cache_limiter("private");
$cache_limit =session_cache_limiter(); //開啟客戶端緩存
echo "緩存限制為:".$cache_limit."\n";
session_cache_expire(30);
$cache_expire = session_cache_expire(); //設(shè)定客戶端緩存時間
echo "客戶端緩存時間為:".$cache_expire."分鐘\n";
session_start();
?>
運行結(jié)果如下:

3,Session數(shù)據(jù)庫存儲
在php中Session 的數(shù)據(jù)庫存儲主要是通過 session_set_save_handler()函數(shù)來實現(xiàn)的。 具體語法如下:
bool session_set_save_handler(string open,string close,string read,string write,string destroy,string gc);

下面分別將這6個參數(shù)(函數(shù))分裝起來,在學習完面向?qū)ο缶幊毯螅蠹視幸粋€更加清晰的認識。
(1) 封裝session_open()函數(shù),代碼如下:
function _session_open($save_path,$session_name){
global $handle;
$handle =mysql_connect('localhost','root','root')or die('數(shù)據(jù)庫連接失??!');
mysql_select_db('db_database11',$handle)or die('數(shù)據(jù)庫不存在');
return(true);
}
(2)封裝session_close()函數(shù),代碼如下:
function _session_close(){
global $handle;
mysql_close($handle);
return(true);
}
(3) 封裝 session_read()函數(shù),在函數(shù)中設(shè)定當前時間的UNIX時間戳,根據(jù)$key查找Session名片及內(nèi)容。代碼如下:
function _session_read($key){
golbal $handle; //全局變量$handle 連接數(shù)據(jù)庫
$time =time(); //設(shè)定當前時間
$sql ="select session_data from tb_session where session_key = '$key' and session_time>'$time'";
$result =mysql_query($ssql,$handle);
$row =mysql_fetch_array($result);
if($row){
return($row['session_data']);
}else{
return(false);
}
}
(4) 封裝session_write()函數(shù),函數(shù)設(shè)定Session的失效時間,查找到Session的名稱及內(nèi)容,如果查詢結(jié)果為空。則將頁面中Session根據(jù)session_id,session_name,失效時間,插入數(shù)據(jù)庫中。如果查詢結(jié)果不為空,則根據(jù) $key修改數(shù)據(jù)庫中Session存儲信息。代碼如下:
function _session_write($key,$data){
global $handle;
$time = 60*60;
$lapse_time =time()+$time; //得到UNIX時間戳
$sql = "select session_data from tb_session where session_key ='$key' and session_time>$lapse_time";
$result =mysql_query($sql,$handle);
if(mysql_num_rows($result)==0){ //沒有結(jié)果
$sql ="insert into tb_session values('$key','$data',$lapse_time)";
$result =mysql_query($sql,$handle);
}else{
$sql ="update tb_session set session_key='$key',session_data ='$data',session_time =$lapse_time where session_key ='$key'";
$result =mysql_query($sql,$handle);
}
return($result);
}
(5) 封裝session_destroy(),根據(jù)$key刪除數(shù)據(jù)庫中的Sessin.代碼如下:
function _session_destroy(){
global $handle;
$sql ="delete from tb_session where session_key ='$key'";
$result =mysql_query($sql,$handle);
}
(6)封裝session_gc(),根據(jù)Session的失效時間刪除過期的Session,示例代碼如下:
functin _session_gc($expiry_time){
global $handle;
$sql ="delete from tb_session where session_expiry_time<$expiry_time";
$result =mysql_query($sql,$handle);
return($result);
}
具體的代碼運行就不做了,等到學完面向?qū)ο蟮木幊痰臅r候給大家演示下哦。
相關(guān)文章
php擴展Zend?Framework框架——Validate擴展
這篇文章介紹了php擴展Zend?Framework框架,文中通過示例代碼介紹的非常詳細。對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2008-01-01
php實現(xiàn)在限定區(qū)域里自動調(diào)整字體大小的類實例
這篇文章主要介紹了php實現(xiàn)在限定區(qū)域里自動調(diào)整字體大小的類,實例分析了php操作圖片及字體的技巧,具有一定參考借鑒價值,需要的朋友可以參考下2015-04-04
PHP四種排序算法實現(xiàn)及效率分析【冒泡排序,插入排序,選擇排序和快速排序】
這篇文章主要介紹了PHP四種排序算法實現(xiàn)及效率分析,結(jié)合具體實例形式分析了php冒泡排序,插入排序,選擇排序和快速排序的具體定義、用法及算法復雜度分析,具有一定參考借鑒價值,需要的朋友可以參考下2018-04-04

