侯体宗的博客
  • 首页
  • Hyperf版
  • beego仿版
  • 人生(杂谈)
  • 技术
  • 关于我
  • 更多分类
    • 文件下载
    • 文字修仙
    • 中国象棋ai
    • 群聊
    • 九宫格抽奖
    • 拼图
    • 消消乐
    • 相册

session 加入mysql库的方法

数据库  /  管理员 发布于 6年前   141

我们知道,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库的资料整理,需要的朋友可以参考下。


  • 上一条:
    MySQL的一条慢SQL查询导致整个网站宕机的解决方法
    下一条:
    Mysql中新建用户及授权的方法分享
  • 昵称:

    邮箱:

    0条评论 (评论内容有缓存机制,请悉知!)
    最新最热
    • 分类目录
    • 人生(杂谈)
    • 技术
    • linux
    • Java
    • php
    • 框架(架构)
    • 前端
    • ThinkPHP
    • 数据库
    • 微信(小程序)
    • Laravel
    • Redis
    • Docker
    • Go
    • swoole
    • Windows
    • Python
    • 苹果(mac/ios)
    • 相关文章
    • 分库分表的目的、优缺点及具体实现方式介绍(0个评论)
    • DevDB - 在 VS 代码中直接访问数据库(0个评论)
    • 在ubuntu系统中实现mysql数据存储目录迁移流程步骤(0个评论)
    • 在mysql中使用存储过程批量新增测试数据流程步骤(0个评论)
    • php+mysql数据库批量根据条件快速更新、连表更新sql实现(0个评论)
    • 近期文章
    • 在go中实现一个常用的先进先出的缓存淘汰算法示例代码(0个评论)
    • 在go+gin中使用"github.com/skip2/go-qrcode"实现url转二维码功能(0个评论)
    • 在go语言中使用api.geonames.org接口实现根据国际邮政编码获取地址信息功能(1个评论)
    • 在go语言中使用github.com/signintech/gopdf实现生成pdf分页文件功能(0个评论)
    • gmail发邮件报错:534 5.7.9 Application-specific password required...解决方案(0个评论)
    • 欧盟关于强迫劳动的规定的官方举报渠道及官方举报网站(0个评论)
    • 在go语言中使用github.com/signintech/gopdf实现生成pdf文件功能(0个评论)
    • Laravel从Accel获得5700万美元A轮融资(0个评论)
    • 在go + gin中gorm实现指定搜索/区间搜索分页列表功能接口实例(0个评论)
    • 在go语言中实现IP/CIDR的ip和netmask互转及IP段形式互转及ip是否存在IP/CIDR(0个评论)
    • 近期评论
    • 122 在

      学历:一种延缓就业设计,生活需求下的权衡之选中评论 工作几年后,报名考研了,到现在还没认真学习备考,迷茫中。作为一名北漂互联网打工人..
    • 123 在

      Clash for Windows作者删库跑路了,github已404中评论 按理说只要你在国内,所有的流量进出都在监控范围内,不管你怎么隐藏也没用,想搞你分..
    • 原梓番博客 在

      在Laravel框架中使用模型Model分表最简单的方法中评论 好久好久都没看友情链接申请了,今天刚看,已经添加。..
    • 博主 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 @1111老铁这个不行了,可以看看近期评论的其他文章..
    • 1111 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 网站不能打开,博主百忙中能否发个APP下载链接,佛跳墙或极光..
    • 2017-06
    • 2017-08
    • 2017-09
    • 2017-10
    • 2017-11
    • 2018-01
    • 2018-05
    • 2018-10
    • 2018-11
    • 2020-02
    • 2020-03
    • 2020-04
    • 2020-05
    • 2020-06
    • 2020-07
    • 2020-08
    • 2020-09
    • 2021-02
    • 2021-04
    • 2021-07
    • 2021-08
    • 2021-11
    • 2021-12
    • 2022-02
    • 2022-03
    • 2022-05
    • 2022-06
    • 2022-07
    • 2022-08
    • 2022-09
    • 2022-10
    • 2022-11
    • 2022-12
    • 2023-01
    • 2023-03
    • 2023-04
    • 2023-05
    • 2023-07
    • 2023-08
    • 2023-10
    • 2023-11
    • 2023-12
    • 2024-01
    • 2024-03
    Top

    Copyright·© 2019 侯体宗版权所有· 粤ICP备20027696号 PHP交流群

    侯体宗的博客