session 參加mysql庫的辦法。本站提示廣大學習愛好者:(session 參加mysql庫的辦法)文章只能為提供參考,不一定能成為您想要的結果。以下是session 參加mysql庫的辦法正文
我們曉得,session是一種會話技巧,用來完成跨劇本同享數據或許檢測跟蹤用戶狀況。
session的任務道理
(1)當一個session第一次被啟用時,一個獨一的標識被存儲於當地的cookie中。
(2)起首應用session_start()函數,PHP從session倉庫中加載曾經存儲的session變量。
(3)當履行PHP劇本時,經由過程應用session_register()函數注冊session變量。
(4)當PHP劇本履行停止時,未被燒毀的session變量會被主動保留在當地必定途徑下的session庫中,這個途徑可以經由過程php.ini文件中的session.save_path指定,下次閱讀網頁時可以加載應用。
session是寄存在辦事器真個文件裡的,是以session有能夠由於文件數目過量,會在查詢session文件和讀取的時刻發生壓力。普通我們有三種處理計劃
1.應用文件分層(缺陷:I/O操作是體系的一個瓶頸,即便分層也不克不及防止此成績)
2.將session放入數據庫
3.將session放在內存中(非關系性數據庫)(缺陷:對辦事器內存請求教高)
跟著 session的增長,治理曾經不便利。
是以我們選用一個折衷的方法,將session存入mysql數據庫,也就是我們要講的重點.
樹立一個表治理 session 。
更改 session的存儲機制,讓 session 不再存在文件中,而是入庫。
更該存儲機制,只須要在文件中增長函數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 渣滓收受接管時光,session有用期 session_set_save_handler( "open","close","read","write","destroy","gc" ); //銜接數據庫 function open(){ @$link = mysql_connect('127.0.0.1', 'root', 'root'); mysql_query('set names utf8'); mysql_query('use wangbin'); //<span>open 回調函數相似於類的結構函數, 在會話翻開的時刻會被挪用。 這是主動開端會話或許經由過程挪用 session_start() 手動開端會話 以後第一個被挪用的回調函數。 此回調函數操作勝利前往TRUE,反之前往FALSE。</span> } function close(){ mysql_close(); //<span>close 回調函數相似於類的析構函數。 在 write 回調函數挪用以後挪用。 當挪用 session_write_close() 函數以後, 也會挪用 close 回調函數。 此回調函數操作勝利前往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>假如會話中稀有據,read 回調函數必需前往將會話數據編碼(序列化)後的字符串。 </span></li><li class="alt"><span>假如會話中沒稀有據,read 回調函數前往空字符串。 </span></li><li class="alt"><span>在主動開端會話或許經由過程挪用 session_start() 函數手動開端會話以後,</span></li><li class="alt"><span>PHP 外部挪用 read 回調函數來獲得會話數據。 在挪用 read 之前,PHP會挪用open回調函數。 </span></li><li class="alt"><span>read 回調前往的序列化以後的字符串格局必需與 write 回調函數保留數據時的格局完整分歧。</span></li><li class="alt"><span>PHP 會主動反序列化前往的字符串並填充 $_SESSION 超等全局變量。 </span></li><li class="alt"><span>固然數據看起來和 serialize() 函數很類似, 然則須要提示的是,它們是分歧的。 </span></li><li class="alt"><span>請參考: 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>在會話保留數據時會挪用 write 回調函數。 此回調函數吸收以後會話ID和$_SESSION中數據序列化以後的字符串作為參數。 序列化會話數據的進程由 PHP 依據 session.serialize_handler 設定值來完成。</span> <span>序列化後的數據將和會話 ID 聯系關系在一路停止保留。 當挪用 read 回調函數獲得數據時, 所前往的數據必需要和傳入write回調函數的數據完整堅持分歧。</span><span> PHP 會在劇本履行終了或挪用 session_write_close() 函數以後挪用此回調函數。 留意,在挪用完此回調函數以後,PHP 外部會挪用 close 回調函數。 </span> Note: <span>PHP 會在輸入流寫入終了而且封閉以後 才挪用 write 回調函數, 所以在 write 回調函數中的調試信息不會輸入到閱讀器中。 假如須要在 write 回調函數中應用調試輸入, 建議將調試輸入寫入到文件。</span> */ } function destroy($sess_id){ echo __FUNCTION__; $sql = "delete from `session` where session_id = '$sess_id'"; return mysql_query($sql); /* <span>當挪用 session_destroy() 函數,或許挪用 session_regenerate_id() 函數而且設置 destroy 參數為 TRUE 時, 會挪用此回調函數。此回調函數操作勝利前往 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>為了清算會話中的舊數據,PHP 會不時的挪用渣滓搜集回調函數。 挪用周期由 session.gc_probability 和 session.gc_divisor 參數掌握。 傳入到此回調函數的 lifetime 參數由 session.gc_maxlifetime 設置。 此回調函數操作勝利前往 TRUE,反之前往 FALSE。</span> */ } header("content-type:text/html;charset=utf8"); session_start(); $_SESSION['name']='aa'; //echo session_id(); echo $_SESSION['name'];
總結 session 運轉機制:
1. 翻開 session 時,語法上履行函數 session_start() ,php 的session 機制讀取閱讀器真個 cookie,語法上表現為$_cookie['PHPSESSID']。
2. 依據 cookie 找到存儲在辦事器真個 session數據。
3. 把 session 數據反序列化,賦值給變量 $_SESSION。
4. 以後對變量 $_SESSION 的操作都是對變量的操作,不會更新 session文件。
5. 能否履行了 session_destroy() 函數,假如履行了,那末刪除辦事器真個session 文件。
6. 劇本停止時,斷定能否有 sessin 文件,或許說能否履行過session_destroy() 辦法。假如沒有履行過,則把 $_SESSION 變量中的數據寫入到 session文件中。假如履行過,那末甚麼也不做.
以上就是對session 參加 mysql庫的材料整頓,須要的同伙可以參考下。