session 加入mysql库的方法_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库的资料整理,需要的朋友可以参考下。

以上是小编为您精心准备的的内容,在的博客、问答、公众号、人物、课程等栏目也有的相关内容,欢迎继续使用右上角搜索按钮进行搜索session
, 入库
, 加入mysql
如何加入mysql库
mysql session、mysql kill session、mysql session 查询、php session mysql、mysql set session,以便于您获取更多的相关知识。

时间: 2024-10-17 14:41:17

session 加入mysql库的方法_Mysql的相关文章

linux忘记mysql密码处理方法_Mysql

linux忘记mysql密码处理方法: # /etc/init.d/mysql stop # mysqld_safe --user=mysql --skip-grant-tables --skip-networking & # mysql -u root mysql mysql> update user set password=password('newpassword') where user='root'; mysql> flush privileges; mysql> q

Ubuntu与windows双系统下共用MySQL数据库的方法_Mysql

双系统配置及MySQL数据库存储情境:Windows XP下d:\mysql\data中存有MySQL数据库,Linux系统为Ubuntu Server 9.10. 双系统安装完毕,利用GURB启动到Ubuntu Server 9.10,以管理员身份登录. 1)并读写方式(RW)认方式挂载Windows中D分区至/media/wind. 2)更改/media/wind/mysql/data权限 sudo chow mysql:mysql /media/wind/mysql/data (其中两个m

使用dreamhost空间实现MYSQL数据库备份方法_Mysql

如何利用SSH(Shell)来备份和恢复MySQL数据库的方法 例如: 数据库参数为:: MySQL地址:mysql.dh.net MySQL名称:mysql_dbname MySQL用户:mysql_dbuser MySQL密码:mysql_dbpass 我要把数据库备份为bak.sql 步骤: 同样,使用windows系统自己带的telnet或者去下载一个putty来,登陆以后,一路cd到自己觉得合适的目录下(确认当前目录可写). 输入下面的命令: mysqldump -h mysql.dh

ubuntu linux下使用Qt连接MySQL数据库的方法_Mysql

环境说明: ubuntu 10.04.2 QtSDK (1.5G安装包的那个) mysql5.1 1.安装MySQL Linux下完整的MySQL开发需要安装服务器端,如果安装客户端也没什么不好.直接在软件中心搜mysql,把client和server选上. server在安装时会提示为root用户设置密码,设一个好了. 我使用的是mysql5.1版本,用户名密码存储在一个叫mysql的数据库里,只有管理员级别才能看到. 如果直接在终端中输入 mysql,可能会提示ERROR 1045 (280

MySQL数据库备份与恢复方法_Mysql

常有新手问我该怎么备份数据库,下面介绍3种备份数据库的方法: (1)备份数据库文件 MySQL中的每一个数据库和数据表分别对应文件系统中的目录和其下的文件.在Linux下数据库文件的存放目录一般为/var/lib/mysql.在Windows下这个目录视MySQL的安装路径而定,DiaHosting的技术员一般为客户安装在D:serversoftmysql下.如,有一个名为bbs的数据库,那么bbs的数据库文件会存放在/var/lib/mysql/bbs(linux)或者D:serversoft

同时运行多个MySQL服务器的方法_Mysql

如果你想要运行多个服务器,最容易的方法是用不同的TCP/IP端口和套接字文件重新编译服务器,因此他们不是侦听同一个TCP/IP端口或套接字. 假设一个现存服务器配置为缺省端口号和套接字文件, 那么用一个这样configure命令行设置新的服务器: shell> ./configure --with-tcp-port=port_number  --with-unix-socket=file_name  --prefix=/usr/local/mysql-3.22.9 这里port_number和f

在CentOS上MySQL数据库服务器配置方法_Mysql

无意中还找到了CentOS的专业论坛,记住:http://www.centospub.com 于是,开始的学习配置 本次环境: CentOS系统, mysql-server(版本忘了,因为是使用yum安装的) 过程如下(转载,根据本人安装详细要求,略加修改) : 在提到网站构架的时候,我们经常能够看到"LAMP"的说法,它就是"Linux + Apache + MySQL + PHP". MySQL+PHP的协同成功案例已经很多了.比如国外的PHPBB,VBB,国内

找到一种不错的从SQLServer转成Mysql数据库的方法_Mysql

年初的时候一直在做一个网站MSSQL2000 -> MySQL5的迁移工作,因为采用了不同的程序系统,所以主要问题在数据的迁移.由于2个系统数据库结构差异非常大,不方便采取SQL SERVER里导入MYSQL的ODBC数据源的功能(也不推荐这么做,字段类型等不同点会搞死人的-),因此就在WINDOWS下自己写PHP脚本从SQLSERVER里读数据,然后按照新系统的需要处理之后插入MYSQL里面,灵活也比较方便.实际过程主要有下面几个问题: 1.数据库的连接,主要是连接SQL SERVER.主要有

使用FriendFeed来提升MySQL性能的方法_Mysql

 背景 我们使用MySQL存储了FriendFeed的所有数据.数据库随着用户基数的增长而增长了很多.现在已经存储了超过2.5亿条记录与一堆涵盖了从评论和"喜欢"到好友列表的其他数据. 随着数据的增长,我们也曾迭代地解决了随着如此迅猛的增长而带来的扩展性问题.我们的尝试很有代表性,例如使用只读mysql从节点和memcache来增加读取吞吐量,对数据库进行分片来提高写入吞吐量.然而,随着业务的增长,添加新功能比扩展既有功能以迎合更多的流量变得更加困难. 特别的,对 schema 做改动