亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 數據庫 > MySQL > 正文

session 加入mysql庫的方法

2024-07-24 13:10:03
字體:
來源:轉載
供稿:網友

我們知道,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,加入mysql,如何加入mysql庫,入庫

 更改 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庫的資料整理,需要的朋友可以參考下。


注:相關教程知識閱讀請移步到MYSQL教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
日韩免费看的电影电视剧大全| 久久久国产一区| 蜜臀久久99精品久久久久久宅男| 日韩成人av网| 久久精品视频在线播放| 热99精品里视频精品| 久久久久久亚洲精品不卡| 亚洲毛茸茸少妇高潮呻吟| 日韩av在线不卡| 亚洲午夜女主播在线直播| 亚洲成人网在线| 日韩av在线免播放器| 亚洲人精选亚洲人成在线| 日韩欧美第一页| 日韩精品免费在线视频| 久久久久一本一区二区青青蜜月| 国产69精品久久久久久| 久久久精品影院| 成人午夜黄色影院| 久99久在线视频| 日韩av在线导航| 国产激情视频一区| 亚洲精品国产精品国自产观看浪潮| 91热精品视频| 亚洲免费视频在线观看| 亚洲成人1234| 亚洲专区在线视频| 亚洲一区二区久久久久久久| 亚洲片在线观看| 久久久久久久国产精品| 性夜试看影院91社区| 法国裸体一区二区| 久久国产精品久久久久久| 亚洲日本aⅴ片在线观看香蕉| 精品激情国产视频| 亚洲黄色av女优在线观看| 91免费看片网站| 国产亚洲欧美aaaa| 久久天天躁狠狠躁夜夜爽蜜月| 国产精品久久久久免费a∨大胸| 91久久国产精品| 日韩黄色av网站| 日本19禁啪啪免费观看www| 成人激情免费在线| 最新国产精品亚洲| 北条麻妃一区二区三区中文字幕| 久久久久久网站| 91亚洲精品在线| 欧美极品少妇全裸体| 亚洲欧美日韩一区在线| 2019中文在线观看| 91精品久久久久久久久不口人| 欧美在线免费视频| 亚洲男人天堂2019| 国产精品久久久久影院日本| 欧亚精品中文字幕| 亚洲一区二区三区在线视频| 久久国产精品久久久久久久久久| 国产精品久久久久av免费| 亚洲色在线视频| 国产欧美精品xxxx另类| 亚洲欧美激情精品一区二区| 亚洲欧美中文日韩v在线观看| 亚洲欧美色婷婷| 亚洲精品一区二三区不卡| 欧美俄罗斯乱妇| 情事1991在线| 亚洲欧美在线播放| 国产成人涩涩涩视频在线观看| 一本一本久久a久久精品综合小说| 一区二区三区精品99久久| 日韩av一区二区在线| 午夜精品久久久久久久久久久久久| 92看片淫黄大片看国产片| 欧美高清第一页| 不卡av在线网站| 国产一区二区视频在线观看| 欧美成人免费va影院高清| 久久国产精品久久久久久| 日韩av免费在线播放| 国产精品日韩精品| 国产精品一区二区三| 国产精品啪视频| 福利一区视频在线观看| 亚洲综合精品一区二区| 日韩精品中文字幕视频在线| 欧美理论电影在线播放| 亚洲a级在线播放观看| 久久亚洲综合国产精品99麻豆精品福利| 91美女高潮出水| 国产98色在线| 97成人精品区在线播放| 日韩精品黄色网| 川上优av一区二区线观看| 久久成年人免费电影| 亚洲免费人成在线视频观看| 欧亚精品在线观看| 亚洲国产精品yw在线观看| 97碰在线观看| 久久久999国产| 国产精品一区二区三区久久久| 韩日欧美一区二区| 中文字幕9999| 亚洲精品视频免费在线观看| 91福利视频在线观看| 欧美日韩第一视频| 欧美性猛交xxxx偷拍洗澡| 清纯唯美日韩制服另类| 国产精品在线看| 国产xxx69麻豆国语对白| 欧美激情精品久久久| 日韩欧美在线视频免费观看| 亚洲精品国产精品国自产观看浪潮| 欧美大片在线看| 欧美精品一区在线播放| 欧美在线视频免费观看| 欧美精品18videos性欧美| 亚洲国产精品系列| 97色在线视频| 国产精品美女久久久久av超清| 日韩中文字幕精品视频| 亚洲精品视频在线观看视频| 午夜精品美女自拍福到在线| 精品露脸国产偷人在视频| 欧美精品在线观看| 日韩欧美国产中文字幕| 欧美激情在线观看视频| 色伦专区97中文字幕| 亚洲自拍欧美色图| 国产精品你懂得| 亚洲一区二区三区视频| 久久久久久91香蕉国产| 91精品久久久久久综合乱菊| 日韩福利视频在线观看| 国产精品久久久久久久久久99| 中文字幕欧美在线| 久久深夜福利免费观看| 亚洲网站在线看| 亚洲最新av网址| 亚洲另类欧美自拍| 午夜精品蜜臀一区二区三区免费| 亚洲精品成人久久久| 欧美日韩加勒比精品一区| 久久99国产综合精品女同| 亚洲第一天堂av| 日本一本a高清免费不卡| 中文字幕亚洲第一| 欧美裸体xxxx极品少妇软件| 精品美女永久免费视频| 亚洲日本成人女熟在线观看| 国产精品盗摄久久久| 国产欧美日韩91| 日韩免费在线播放| 欧美日韩电影在线观看| 91精品国产成人www| 国产欧美精品久久久| 亚洲电影在线观看| 日韩欧美亚洲国产一区| 亚州成人av在线| 成人动漫网站在线观看| 亚洲аv电影天堂网| 亚洲欧洲日本专区| 成人久久久久久| 久久久中精品2020中文|