知识大全 关于PHP session 存储方式的详细介绍

Posted 数据库

篇首语:临文乍了了,彻卷兀若无。本文由小常识网(cha138.com)小编为大家整理,主要介绍了知识大全 关于PHP session 存储方式的详细介绍相关的知识,希望对你有一定的参考价值。

关于PHP session 存储方式的详细介绍  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!

  PHP为sesion的存储提供了三种方式: 文件/ 内存/ 自定义存储 默认是使用文件存储 在访问量大的网站上采用这种方式就不大合适 因为这样会导致大量的输入输出的冗余 下面介绍一种基于Mysql数据库的session存储方式 首先要进行的配置如下: >php ini中将session save_handler = files 中的files改为User 其他默认即可 重启Apache(好像没改也行啊) >本实例创建的数据库名叫php username: root password:root 本实例设计的数据库的表结构如下所示:

复制代码 代码如下: create table mysession( session_key char( ) not null session_data text session_expiry int( ) primary key(session_key) );

   第一列表示存储session ID 第二列存储session中的数据 第三列存储有效期 呵呵(表结构就这么简单) 下面就是关键的那份自定义函数的实现session_set_save_handler( )

复制代码 代码如下: <?php function mysession_open($save_path $session_name) @mysql_connect("localhost" "root" "root") //选择数据库之前需要先连接数据库服务器 or die("数据库服务器连接失败"); @mysql_select_db("php") //选择数据库mydb or die("数据库不存在或不可用"); return true; function mysession_close() return true; function mysession_read($key) @mysql_connect("localhost" "root" "root") //选择数据库之前需要先连接数据库服务器 or die("数据库服务器连接失败"); @mysql_select_db("php") //选择数据库mydb or die("数据库不存在或不可用"); $expiry_time = time(); //获取Session失效时间 //执行SQL语句获得Session的值 $query = @mysql_query("select session_data from mysession " "where session_key = $key and session_expiry > $expiry_time") or die("SQL语句执行失败"); if($row = mysql_fetch_array($query)) return $row[ session_data ]; else return false; function mysession_write($key $data) @mysql_connect("localhost" "root" "root") //选择数据库之前需要先连接数据库服务器 or die("数据库服务器连接失败"); @mysql_select_db("php") //选择数据库mydb or die("数据库不存在或不可用"); $expiry_time = time() + ; //获取Session失效时间 //查询Session的键值是否已经存在 $query = @mysql_query("select session_data from mysession " "where session_key = $key ") or die("SQL语句执行失败"); //如果不存在 则执行插入操作 否则执行更新操作 if(mysql_numrows($query) == ) //执行SQL语句插入Session的值 $query = @mysql_query("insert into mysession values( $key $data $expiry_time)") or die("SQL语句执行失败"); else //执行SQL语句更新Session的值 $query = @mysql_query("update mysession set " "session_data = $data session_expiry = $expiry_time " "where session_key = $key ") or die("SQL语句执行失败"); return $query; function mysession_destroy($key) @mysql_connect("localhost" "root" "root") //选择数据库之前需要先连接数据库服务器 or die("数据库服务器连接失败"); @mysql_select_db("php") //选择数据库mydb or die("数据库不存在或不可用"); //执行SQL语句删除Session $query = @mysql_query("delete from mysession where session_key = $key ") or die("SQL语句执行失败"); return $query; function mysession_gc($expiry_time) @mysql_connect("localhost" "root" "root") //选择数据库之前需要先连接数据库服务器 or die("数据库服务器连接失败"); @mysql_select_db("php") //选择数据库mydb or die("数据库不存在或不可用"); $expiry_time = time(); //执行SQL语句删除Session $query = @mysql_query("delete from mysession where session_expiry < $expiry_time") or die("SQL语句执行失败"); return $query; //设置用户自定义Session存储 session_set_save_handler( mysession_open mysession_close mysession_read mysession_write mysession_destroy mysession_gc ); ?>

   最后面就是测试代码 >存储页面 save php

复制代码 代码如下: <?php include( user define session inc php ); //包含session_set_save_handler定义的文件 session_start(); $_SESSION[ username ] = "Simon"; $_SESSION[ password ] = " "; ?>

   显示页面 show php

复制代码 代码如下: <?php include( user define session inc php ); //包含session_set_save_handler定义的文件 session_start(); echo "UserName:" $_SESSION[ username ] "<BR>"; echo "PassWord:" $_SESSION[ password ] "<BR>"; ?> cha138/Article/program/PHP/201311/21233

相关参考

知识大全 解析php session

本篇文章是对php中session_set_save_handler函数的用法(mysql)进行了详细的分析介绍需要的朋友参考下 复制代码代码如下:<?php/*===========

知识大全 php中如何同时使用session和cookie来保存用户登录信息

本篇文章是对在php中同时使用session和cookie来保存用户登录信息的实现代码进行了详细的分析介绍需要的朋友参考下   同时使用session和cookie来保存用户登录信息数据库连

知识大全 详解PHP会话存储方式

详解PHP会话存储方式  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!  先确认会话是否自动开启还是

知识大全 关于php循环跳出的问题

本篇文章是对php中循环跳出的问题进行了详细的分析介绍需要的朋友参考下 复制代码代码如下:cha138/Article/program/PHP/201311/20938

知识大全 ASP.NET中的session存储模式运用

ASP.NET中的session存储模式运用  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!  在中

知识大全 解析PHP的session过期设置

解析PHP的session过期设置  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!  网上很多人给出

知识大全 PHP session

PHPsession  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!  本文将这些问题做一个简单的汇

知识大全 使用PHP会话(Session)实现用户登陆功能

使用PHP会话(Session)实现用户登陆功能  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!&n

知识大全 关于php 接口问题(php接口主要也就是运用curl,curl函数)

本篇文章是对php中的接口问题(php接口主要也就是运用curlcurl函数)进行了详细的分析介绍需要的朋友参考下   接口问题php调用接口最主要的就是使用curl抓取信息复制代码代码如下

知识大全 .net调用存储过程详细介绍

  连接字符串代码如下:stringconn=ConfigurationManagerConnectionStrings["NorthwindConnectionString"]ConnectionS