欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

session 加入mysql庫(kù)的方法

 更新時(shí)間:2016年07月15日 14:57:30   投稿:lqh  
本篇文章主要介紹了 session 加入mysql的方法,大家在開發(fā)過(guò)程中會(huì)遇到對(duì)數(shù)據(jù)庫(kù)的操作,有時(shí)會(huì)遇到Session加入mysql,這里給大家提供了方法,

我們知道,session是一種會(huì)話技術(shù),用來(lái)實(shí)現(xiàn)跨腳本共享數(shù)據(jù)或者檢測(cè)跟蹤用戶狀態(tài)。

session的工作原理

(1)當(dāng)一個(gè)session第一次被啟用時(shí),一個(gè)唯一的標(biāo)識(shí)被存儲(chǔ)于本地的cookie中。

(2)首先使用session_start()函數(shù),PHP從session倉(cāng)庫(kù)中加載已經(jīng)存儲(chǔ)的session變量。

(3)當(dāng)執(zhí)行PHP腳本時(shí),通過(guò)使用session_register()函數(shù)注冊(cè)session變量。

(4)當(dāng)PHP腳本執(zhí)行結(jié)束時(shí),未被銷毀的session變量會(huì)被自動(dòng)保存在本地一定路徑下的session庫(kù)中,這個(gè)路徑可以通過(guò)php.ini文件中的session.save_path指定,下次瀏覽網(wǎng)頁(yè)時(shí)可以加載使用。

 session是存放在服務(wù)器端的文件里的,因此session有可能因?yàn)槲募?shù)量過(guò)多,會(huì)在查詢session文件以及讀取的時(shí)候產(chǎn)生壓力。一般我們有三種解決方案

1.使用文件分層(缺點(diǎn):I/O操作是系統(tǒng)的一個(gè)瓶頸,即使分層也不能避免此問(wèn)題)

2.將session放入數(shù)據(jù)庫(kù)

3.將session放在內(nèi)存中(非關(guān)系性數(shù)據(jù)庫(kù))(缺點(diǎn):對(duì)服務(wù)器內(nèi)存要求教高)

隨著 session的增加,管理已經(jīng)不方便。

因此我們選用一個(gè)折中的辦法,將session存入mysql數(shù)據(jù)庫(kù),也就是我們要講的重點(diǎn).

建立一個(gè)表管理 session 。

 

 更改 session的存儲(chǔ)機(jī)制,讓 session 不再存在文件中,而是入庫(kù)。

更該存儲(chǔ)機(jī)制,只需要在文件中增加函數(shù)session_set_save_handler() 便可。

<?php 
ini_set("session.save_handler","user");  
//session.gc_probability = 1 分子  
ini_set("session.gc_probability",1);  
//session.gc_divisor = 1000 分母  
ini_set("session.gc_divisor",2);  
//session.gc_maxlifetime = 1440 垃圾回收時(shí)間,session有效期  
session_set_save_handler( "open","close","read","write","destroy","gc" ); 
//連接數(shù)據(jù)庫(kù)  
function open(){  
 @$link = mysql_connect('127.0.0.1', 'root', 'root');  
 mysql_query('set names utf8');  
 mysql_query('use wangbin'); 
 //<span>open 回調(diào)函數(shù)類似于類的構(gòu)造函數(shù), 在會(huì)話打開的時(shí)候會(huì)被調(diào)用。 
 這是自動(dòng)開始會(huì)話或者通過(guò)調(diào)用 session_start() 手動(dòng)開始會(huì)話 
 之后第一個(gè)被調(diào)用的回調(diào)函數(shù)。 此回調(diào)函數(shù)操作成功返回TRUE,反之返回FALSE。</span> 
}  
function close(){  
 mysql_close(); 
 //<span>close 回調(diào)函數(shù)類似于類的析構(gòu)函數(shù)。 在 write 回調(diào)函數(shù)調(diào)用之后調(diào)用。 
 當(dāng)調(diào)用 session_write_close() 函數(shù)之后, 
 也會(huì)調(diào)用 close 回調(diào)函數(shù)。 此回調(diào)函數(shù)操作成功返回TRUE,反之返回FALSE。</span>  
}  
function read($sess_id){  
 $sql = "select session_data from `session` where session_id = '$sess_id'";  
 $result = mysql_query($sql);  
 if($rows = mysql_fetch_assoc($result)){ 
  return $rows['session_data']; } 
 else{ 
  return ''; 
 } 
<ol class="dp-py" start="1"><li class="alt"><span>如果會(huì)話中有數(shù)據(jù),read 回調(diào)函數(shù)必須返回將會(huì)話數(shù)據(jù)編碼(序列化)后的字符串。 </span></li><li class="alt"><span>如果會(huì)話中沒(méi)有數(shù)據(jù),read 回調(diào)函數(shù)返回空字符串。 </span></li><li class="alt"><span>在自動(dòng)開始會(huì)話或者通過(guò)調(diào)用 session_start() 函數(shù)手動(dòng)開始會(huì)話之后,</span></li><li class="alt"><span>PHP 內(nèi)部調(diào)用 read 回調(diào)函數(shù)來(lái)獲取會(huì)話數(shù)據(jù)。 在調(diào)用 read 之前,PHP會(huì)調(diào)用open回調(diào)函數(shù)。 
</span></li><li class="alt"><span>read 回調(diào)返回的序列化之后的字符串格式必須與 write 回調(diào)函數(shù)保存數(shù)據(jù)時(shí)的格式完全一致。</span></li><li class="alt"><span>PHP 會(huì)自動(dòng)反序列化返回的字符串并填充 $_SESSION 超級(jí)全局變量。 
</span></li><li class="alt"><span>雖然數(shù)據(jù)看起來(lái)和 serialize() 函數(shù)很相似, 但是需要提醒的是,它們是不同的。 
</span></li><li class="alt"><span>請(qǐng)參考: session.serialize_handler。</span></li></ol> 
 }  
function write($sess_id,$sess_data){  
 $sql = "insert into `session` (session_id,session_data,session_time) values('$sess_id','$sess_data', now()) on duplicate key update session_data = '$sess_data' , session_time = now()"; //這是為了gc()  
 return mysql_query($sql); 
 /* 
 <span>在會(huì)話保存數(shù)據(jù)時(shí)會(huì)調(diào)用 write 回調(diào)函數(shù)。 此回調(diào)函數(shù)接收當(dāng)前會(huì)話ID以及$_SESSION中數(shù)據(jù)序列化之后的字符串作為參數(shù)。 
 序列化會(huì)話數(shù)據(jù)的過(guò)程由 PHP 根據(jù) session.serialize_handler 設(shè)定值來(lái)完成。</span> 
 <span>序列化后的數(shù)據(jù)將和會(huì)話 ID 關(guān)聯(lián)在一起進(jìn)行保存。 當(dāng)調(diào)用 read 回調(diào)函數(shù)獲取數(shù)據(jù)時(shí), 
 所返回的數(shù)據(jù)必須要和傳入write回調(diào)函數(shù)的數(shù)據(jù)完全保持一致。</span><span> 
 PHP 會(huì)在腳本執(zhí)行完畢或調(diào)用 session_write_close() 函數(shù)之后調(diào)用此回調(diào)函數(shù)。 
 注意,在調(diào)用完此回調(diào)函數(shù)之后,PHP 內(nèi)部會(huì)調(diào)用 close 回調(diào)函數(shù)。 </span> 
 Note: 
 <span>PHP 會(huì)在輸出流寫入完畢并且關(guān)閉之后 才調(diào)用 write 回調(diào)函數(shù), 
 所以在 write 回調(diào)函數(shù)中的調(diào)試信息不會(huì)輸出到瀏覽器中。 
 如果需要在 write 回調(diào)函數(shù)中使用調(diào)試輸出, 建議將調(diào)試輸出寫入到文件。</span> 
  */ 
 }  
function destroy($sess_id){  
 echo __FUNCTION__;  
 $sql = "delete from `session` where session_id = '$sess_id'";  
 return mysql_query($sql); 
 /* 
 <span>當(dāng)調(diào)用 session_destroy() 函數(shù),或者調(diào)用 session_regenerate_id() 函數(shù)并且設(shè)置 destroy 參數(shù)為 TRUE 時(shí), 
 會(huì)調(diào)用此回調(diào)函數(shù)。此回調(diào)函數(shù)操作成功返回 TRUE,反之返回 FALSE。</span> 
 */ 
  
}  
function gc($sess_id){  
 $maxlifetime = ini_set("session.gc_maxlifetime");  
 echo __FUNCTION__;  
 $sql = "delete from `session` where now()-session_time > '$maxlifetime' ";  
 return mysql_query($sql); 
 /* 
 <span>為了清理會(huì)話中的舊數(shù)據(jù),PHP 會(huì)不時(shí)的調(diào)用垃圾收集回調(diào)函數(shù)。 
 調(diào)用周期由 session.gc_probability 和 session.gc_divisor 參數(shù)控制。 
 傳入到此回調(diào)函數(shù)的 lifetime 參數(shù)由 session.gc_maxlifetime 設(shè)置。 
 此回調(diào)函數(shù)操作成功返回 TRUE,反之返回 FALSE。</span> 
 */  
}  
header("content-type:text/html;charset=utf8");  
session_start();  
$_SESSION['name']='aa';  
//echo session_id();  
echo $_SESSION['name']; 

 總結(jié) session 運(yùn)行機(jī)制:

1. 打開 session 時(shí),語(yǔ)法上執(zhí)行函數(shù) session_start() ,php 的session 機(jī)制讀取瀏覽器端的 cookie,語(yǔ)法上表示為$_cookie['PHPSESSID']。

2. 根據(jù) cookie 找到存儲(chǔ)在服務(wù)器端的 session數(shù)據(jù)。

3. 把 session 數(shù)據(jù)反序列化,賦值給變量 $_SESSION。

4. 之后對(duì)變量 $_SESSION 的操作都是對(duì)變量的操作,不會(huì)更新 session文件。

5. 是否執(zhí)行了 session_destroy() 函數(shù),如果執(zhí)行了,那么刪除服務(wù)器端的session 文件。

6. 腳本結(jié)束時(shí),判斷是否有 sessin 文件,或者說(shuō)是否執(zhí)行過(guò)session_destroy() 方法。如果沒(méi)有執(zhí)行過(guò),則把 $_SESSION 變量中的數(shù)據(jù)寫入到 session文件中。如果執(zhí)行過(guò),那么什么也不做.

 以上就是對(duì)session 加入 mysql庫(kù)的資料整理,需要的朋友可以參考下。

相關(guān)文章

  • MySQL中查詢?nèi)罩九c慢查詢?nèi)罩镜幕緦W(xué)習(xí)教程

    MySQL中查詢?nèi)罩九c慢查詢?nèi)罩镜幕緦W(xué)習(xí)教程

    這篇文章主要介紹了MySQL中查詢?nèi)罩九c慢查詢?nèi)罩镜幕緦W(xué)習(xí)教程,文中還提到了MySQL自帶的Mysqldumpslow日志分析工具的使用,需要的朋友可以參考下
    2015-12-12
  • mysql模糊查詢like和regexp小結(jié)

    mysql模糊查詢like和regexp小結(jié)

    在mysql中實(shí)現(xiàn)模糊查詢有兩種方法一種是LIKE/NOT LIKE,另一種是REGEXP/NOT REGEXP方法,下面我來(lái)給大家介紹它們的用法,希望此教程對(duì)各位同學(xué)會(huì)有所幫助。
    2014-09-09
  • MySQL?中的count(*)?與?count(1)?誰(shuí)更快一些?

    MySQL?中的count(*)?與?count(1)?誰(shuí)更快一些?

    這篇文章主要討論MySQL?中?count(*)?與?count(1)?誰(shuí)更快一些?以下討論基于?InnoDB?存儲(chǔ)引擎,并且再文末單獨(dú)說(shuō)一下MyISAM?,感興趣的小伙伴可以參考一下
    2022-02-02
  • MySQL8.0無(wú)法啟動(dòng)3534的解決方法

    MySQL8.0無(wú)法啟動(dòng)3534的解決方法

    本文主要是記錄一下自己使用MySQL的一次踩坑經(jīng)歷,我的MySQL安裝好后,使用一周后的同一時(shí)間必定報(bào)連接失敗,然后查找發(fā)現(xiàn)是MySQL本地服務(wù)沒(méi)有啟動(dòng),下面就詳細(xì)的介紹一下
    2021-06-06
  • mysql索引篇explain命令詳解

    mysql索引篇explain命令詳解

    這篇文章主要介紹了mysql索引篇explain命令詳解,mysql中的explain命令可以用來(lái)查看sql語(yǔ)句是否使用了索引,用了什么索引,有沒(méi)有做全表掃描,更多相關(guān)內(nèi)容需要的小伙伴可以參考一下
    2022-08-08
  • 一文了解MySQL的四大子查詢

    一文了解MySQL的四大子查詢

    本文主要介紹了一文了解MySQL的四大子查詢,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2023-06-06
  • MySQL中文亂碼問(wèn)題解決方案

    MySQL中文亂碼問(wèn)題解決方案

    這篇文章主要介紹了MySQL中文亂碼問(wèn)題解決方案,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-09-09
  • MySQL與JDBC之間的SQL預(yù)編譯技術(shù)講解

    MySQL與JDBC之間的SQL預(yù)編譯技術(shù)講解

    這篇文章主要介紹了MySQL與JDBC之間的SQL預(yù)編譯技術(shù)講解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-11-11
  • 詳解mysql?bit/json/enum/set?的數(shù)據(jù)存儲(chǔ)

    詳解mysql?bit/json/enum/set?的數(shù)據(jù)存儲(chǔ)

    這篇文章主要介紹了mysql?bit/json/enum/set?的數(shù)據(jù)存儲(chǔ),探究的主要內(nèi)容為 int 類類型的存儲(chǔ), 浮點(diǎn)類類型的存儲(chǔ), char 類類型的存儲(chǔ), blob 類類型的存儲(chǔ), enum/json/set/bit 類類型的存儲(chǔ),需要的朋友可以參考下
    2023-09-09
  • MySQL如何解決幻讀問(wèn)題

    MySQL如何解決幻讀問(wèn)題

    在高并發(fā)數(shù)據(jù)庫(kù)系統(tǒng)中,需要保證事務(wù)與事務(wù)之間的隔離性,還有事務(wù)本身的一致性。所以需要解決幻讀問(wèn)題,本文就來(lái)介紹一下,感興趣的可以了解一下
    2021-08-08

最新評(píng)論