热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

Mysql存储PHPSession

首先要进行的配置如下:1phpini中将sessionsave_handlerfiles中的files改为User,其他默认即可,重启Apache2本实例创建的数据库名

首先要进行的配置如下:

1.php.ini中将session.save_handler = files 中的files改为User,其他默认即可,重启Apache

2.本实例创建的数据库名叫php, username: root password:root

本实例设计的数据库的表结构如下所示,代码如下:

  1. create table mysession( 
  2. session_key char(32) not null
  3. session_data text, 
  4. session_expiry int(11), 
  5. primary key(session_key) 
  6. ); 

第一列表示存储session ID,第二列存储session中的数据,第三列存储有效期,下面就是关键的那份自定义函数的实现session_set_save_handler(......),代码如下:

user-define-session-inc.php

  1. function mysession_open($save_path$session_name
  2. @mysql_connect("localhost""root""root"or die("数据库服务器连接失败"); 
  3. @mysql_select_db("php"or die("数据库不存在或不可用"); 
  4. return true; 
  5. function mysession_close() 
  6. return true; 
  7. function mysession_read($key
  8. @mysql_connect("localhost""root""root"or die("数据库服务器连接失败"); 
  9. @mysql_select_db("php"or die("数据库不存在或不可用"); 
  10. $expiry_time = time(); 
  11. $query = @mysql_query("select session_data from mysession where session_key = '$key' and session_expiry > $expiry_time"or die("SQL语句执行失败"); 
  12. if($row = mysql_fetch_array($query)) 
  13. return $row['session_data']; 
  14. else 
  15. return false; 
  16. function mysession_write($key$data
  17. @mysql_connect("localhost""root""root"or die("数据库服务器连接失败"); 
  18. @mysql_select_db("php"or die("数据库不存在或不可用"); 
  19. $expiry_time = time() + 1200; 
  20. $query = @mysql_query("select session_data from mysession where session_key = '$key'"or die("SQL语句执行失败"); 
  21. if(mysql_numrows($query) == 0) 
  22. $query = @mysql_query("insert into mysession values('$key', '$data', $expiry_time)"or die("SQL语句执行失败"); 
  23. else 
  24. $query = @mysql_query("update mysession set session_data = '$data', session_expiry = $expiry_time where session_key = '$key'"or die("SQL语句执行失败"); 
  25. return $query
  26. function mysession_destroy($key
  27. @mysql_connect("localhost""root""root"or die("数据库服务器连接失败"); 
  28. @mysql_select_db("php"or die("数据库不存在或不可用"); 
  29. $query = @mysql_query("delete from mysession where session_key = '$key'"
  30. or die("SQL语句执行失败"); 
  31. return $query
  32. function mysession_gc($expiry_time
  33. @mysql_connect("localhost""root""root"or die("数据库服务器连接失败"); 
  34. @mysql_select_db("php"or die("数据库不存在或不可用"); 
  35. $expiry_time = time(); 
  36. $query = @mysql_query("delete from mysession where session_expiry < $expiry_time"or die("SQL语句执行失败"); 
  37. return $query
  38. session_set_save_handler(&#39;mysession_open&#39;,&#39;mysession_close&#39;,&#39;mysession_read&#39;,&#39;mysession_write&#39;,&#39;mysession_destroy&#39;,&#39;mysession_gc&#39;); 
  39. ?> 

最后面就是测试代码:

1.存储页面 save.php

  1. include(&#39;user-define-session-inc.php&#39;); 
  2. session_start(); 
  3. $_SESSION[&#39;username&#39;] = "Simon"
  4. $_SESSION[&#39;password&#39;] = "123456"
  5. ?> 

2.显示页面 show.php

  1. include(&#39;user-define-session-inc.php&#39;); 
  2. session_start(); 
  3. echo "UserName:".$_SESSION[&#39;username&#39;]." 
  4. "; 
  5. echo "PassWord:".$_SESSION[&#39;password&#39;]." 
  6. "; 
  7. ?>

推荐阅读
  • 本文介绍了在开发Android新闻App时,搭建本地服务器的步骤。通过使用XAMPP软件,可以一键式搭建起开发环境,包括Apache、MySQL、PHP、PERL。在本地服务器上新建数据库和表,并设置相应的属性。最后,给出了创建new表的SQL语句。这个教程适合初学者参考。 ... [详细]
  • PHP图片截取方法及应用实例
    本文介绍了使用PHP动态切割JPEG图片的方法,并提供了应用实例,包括截取视频图、提取文章内容中的图片地址、裁切图片等问题。详细介绍了相关的PHP函数和参数的使用,以及图片切割的具体步骤。同时,还提供了一些注意事项和优化建议。通过本文的学习,读者可以掌握PHP图片截取的技巧,实现自己的需求。 ... [详细]
  • 本文讨论了Alink回归预测的不完善问题,指出目前主要针对Python做案例,对其他语言支持不足。同时介绍了pom.xml文件的基本结构和使用方法,以及Maven的相关知识。最后,对Alink回归预测的未来发展提出了期待。 ... [详细]
  • 本文介绍了在Mac上搭建php环境后无法使用localhost连接mysql的问题,并通过将localhost替换为127.0.0.1或本机IP解决了该问题。文章解释了localhost和127.0.0.1的区别,指出了使用socket方式连接导致连接失败的原因。此外,还提供了相关链接供读者深入了解。 ... [详细]
  • 本文介绍了关于apache、phpmyadmin、mysql、php、emacs、path等知识点,以及如何搭建php环境。文章提供了详细的安装步骤和所需软件列表,希望能帮助读者解决与LAMP相关的技术问题。 ... [详细]
  • 本文介绍了在Windows环境下如何配置php+apache环境,包括下载php7和apache2.4、安装vc2015运行时环境、启动php7和apache2.4等步骤。希望对需要搭建php7环境的读者有一定的参考价值。摘要长度为169字。 ... [详细]
  • mac php错误日志配置方法及错误级别修改
    本文介绍了在mac环境下配置php错误日志的方法,包括修改php.ini文件和httpd.conf文件的操作步骤。同时还介绍了如何修改错误级别,以及相应的错误级别参考链接。 ... [详细]
  • 如何提高PHP编程技能及推荐高级教程
    本文介绍了如何提高PHP编程技能的方法,推荐了一些高级教程。学习任何一种编程语言都需要长期的坚持和不懈的努力,本文提醒读者要有足够的耐心和时间投入。通过实践操作学习,可以更好地理解和掌握PHP语言的特异性,特别是单引号和双引号的用法。同时,本文也指出了只走马观花看整体而不深入学习的学习方式无法真正掌握这门语言,建议读者要从整体来考虑局部,培养大局观。最后,本文提醒读者完成一个像模像样的网站需要付出更多的努力和实践。 ... [详细]
  • 目录浏览漏洞与目录遍历漏洞的危害及修复方法
    本文讨论了目录浏览漏洞与目录遍历漏洞的危害,包括网站结构暴露、隐秘文件访问等。同时介绍了检测方法,如使用漏洞扫描器和搜索关键词。最后提供了针对常见中间件的修复方式,包括关闭目录浏览功能。对于保护网站安全具有一定的参考价值。 ... [详细]
  • Android系统移植与调试之如何修改Android设备状态条上音量加减键在横竖屏切换的时候的显示于隐藏
    本文介绍了如何修改Android设备状态条上音量加减键在横竖屏切换时的显示与隐藏。通过修改系统文件system_bar.xml实现了该功能,并分享了解决思路和经验。 ... [详细]
  • 标题: ... [详细]
  • 本文介绍了一些Java开发项目管理工具及其配置教程,包括团队协同工具worktil,版本管理工具GitLab,自动化构建工具Jenkins,项目管理工具Maven和Maven私服Nexus,以及Mybatis的安装和代码自动生成工具。提供了相关链接供读者参考。 ... [详细]
  • 本文由编程笔记#小编为大家整理,主要介绍了StartingzookeeperFAILEDTOSTART相关的知识,希望对你有一定的参考价值。下载路径:https://ar ... [详细]
  • 本文介绍了在Linux下安装和配置Kafka的方法,包括安装JDK、下载和解压Kafka、配置Kafka的参数,以及配置Kafka的日志目录、服务器IP和日志存放路径等。同时还提供了单机配置部署的方法和zookeeper地址和端口的配置。通过实操成功的案例,帮助读者快速完成Kafka的安装和配置。 ... [详细]
  • 一句话解决高并发的核心原则
    本文介绍了解决高并发的核心原则,即将用户访问请求尽量往前推,避免访问CDN、静态服务器、动态服务器、数据库和存储,从而实现高性能、高并发、高可扩展的网站架构。同时提到了Google的成功案例,以及适用于千万级别PV站和亿级PV网站的架构层次。 ... [详细]
author-avatar
老6李家小宝
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有