一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

Mysql|Sql Server|Oracle|Redis|MongoDB|PostgreSQL|Sqlite|DB2|mariadb|Access|數據庫技術|

服務器之家 - 數據庫 - Mysql - session 加入mysql庫的方法

session 加入mysql庫的方法

2020-06-17 16:32lqh 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 加入mysql庫的方法

 更改 session的存儲機制,讓 session 不再存在文件中,而是入庫。

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

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
<?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庫的資料整理,需要的朋友可以參考下。

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 奇米激情| www.日本视频| 国外成品精品1688 | 古装床戏做爰无遮挡三级 | 日本人泡妞xxxxxx69 | 免费国产白棉袜踩踏区域 | 日本在线视频网 | 国产精品原创视频 | 不良小说 | 好姑娘在线完整版视频 | 秋霞黄色| 青青草精品在线观看 | 国产精品美女久久久久网站 | 成人中文字幕在线观看 | 精品国产免费久久久久久 | 久久re亚洲在线视频 | 成人永久免费 | 女人把扒开给男人爽 | 国产偷窥 | 成人在线观看网站 | porno美国xxxx | yellow片在线观看 | 美女被狂揉下部羞羞动漫 | 经典三级四虎在线观看 | 热99re久久精品国产首页 | 1313午夜精品理伦片 | 日韩一区二三区无 | 亚洲欧美日本在线观看 | 欧美一卡2卡3卡四卡海外精品 | 香蕉eeww99国产精品 | 色老板免费在线观看 | haodiaose在线精品免费视频 | 亚洲天堂视频在线免费观看 | 欧美成人精品第一区二区三区 | 啊啊啊好大好爽视频 | 日本小网站 | www.久久99| xxx久久| a级情欲片在线观看hd | 9999视频 | 亚洲精品国产精品麻豆99 |