php 数据 session中,在PHP中怎么将session数据保持到数据库中

在PHP中怎么将session数据保持到数据库中

发布时间:2021-01-16 09:37:39

来源:亿速云

阅读:64

作者:Leah

在PHP中怎么将session数据保持到数据库中?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。

PostgreSQL版

首先是数据库的部分--drop table php_session

create unlogged table php_session

(

sess_id varchar(32) primary key,

modify_time timestamp with time zone not null,

sess_data varchar(3000) default ''

);

create index concurrently idx_php_session_modify_time on php_session(modify_time);

--set_session(id, data)

create or replace function set_session(varchar, varchar) returns void as $set_session$

with upsert as (

update php_session

set modify_time = current_timestamp, sess_data = $2

where sess_id = $1

returning 1

)

insert into php_session (sess_id, modify_time, sess_data)

select $1, current_timestamp, $2

where not exists (

select 1 from upsert

);

$set_session$ language sql;

--get_session(id)

create or replace function get_session(varchar) returns varchar as $get_session$

select sess_data from php_session where sess_id = $1

$get_session$ language sql;

--del_session

create or replace function del_session(varchar) returns void as $del_session$

delete from php_session where sess_id = $1

$del_session$ language sql;

--gc_session

create or replace function gc_session() returns void as $del_session$

delete from php_session where modify_time 

$del_session$ language sql;

然后是PHP的部分<?php

session_set_save_handler(

function ($savePath, $sessionName) {//open

return true;

},

function () {//close

return true;

},

function ($id) {//read

$sql = "select get_session($1)";

$stmt = pg_query_params(SESSION_CONN, $sql, array($id));

$result = pg_fetch_row($stmt);

return $result[0];

},

function ($id, $data) {//write

$sql = "select set_session($1, $2)";

pg_query_params(SESSION_CONN, $sql, array($id, $data));

return true;

},

function ($id) {//destroy

$sql = "select del_session($1)";

pg_query_params(SESSION_CONN, $sql, array($id, $data));

return true;

},

function ($maxlifetime) {//gc

//php needn't control the global session gc

return true;

}

);

register_shutdown_function('session_write_close');

?>

然后只要在session_start之前调用这个就可以了

至于SESSION_CONN,那是我定义的一个常量,表示一个指向session数据库的链接而已。

CREATE TABLE IF NOT EXISTS `sessioninfo` (

`sid` varchar(255) NOT NULL,

`value` text NOT NULL,

`expiration` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,

PRIMARY KEY (`sid`)

) ENGINE=InnoDB DEFAULT CHARSET=utf8;

session信息存储到数据库的类:class MySessionHandler implements SessionHandlerInterface {

/**

* @access private

* @var object 数据库连接

*/

private $_dbLink;

/**

* @access private

* @var string 保存session的表名

*/

Private $_sessionTable;

/**

* @access private

* @var string session名

*/

private $_sessionName;

/**

* @const 过期时间

*/

const SESSION_EXPIRE = 10;

public function __construct($dbLink, $sessionTable) {

if(!is_object($dbLink)) {

return false;

}

$this->_dbLink = $dbLink;

$this->_sessionTable = $sessionTable;

}

/**

* 打开

* @access public

* @param string $session_save_path 保存session的路径

* @param string $session_name session名

* @return integer

*/

public function open($session_save_path, $session_name) {

$this->_sessionName = $session_name;

return 0;

}

/**

* 关闭

* @access public

* @return integer

*/

public function close() {

return 0;

}

/**

* 关闭session

* @access public

* @param string $session_id session ID

* @return string

*/

public function read($session_id) {

$query = "SELECT value FROM {$this->_sessionTable} WHERE sid = {$session_id} AND UNIX_TIMESTAMP(expiration) + " . self::SESSION_EXPIRE . " > UNIX_TIMESTAMP(NOW())";

$result = $this->_dbLink->query($query);

if(!isset($value) || empty($value)) {

$value = "";

return $value;

}

$this->_dbLink->query("UPDATE {$this->_sessionTable} SET expiration = CURRENT_TIMESTAMP() WHERE sid = {$session_id}");

$value = $result->fetch_array();

$result->free();

return $value['value'];

}

/**

* 写入session

* @access public

* @param string $session_id session ID

* @param string $session_data session data

* @return integer

*/

public function write($session_id, $session_data) {

$query = "SELECT value FROM {$this->_sessionTable} WHERE sid = '{$session_id}' AND UNIX_TIMESTAMP(expiration) + " . self::SESSION_EXPIRE . " > UNIX_TIMESTAMP(NOW())";

$result = $this->_dbLink->query($query);

$result = $result->fetch_array();

if(!empty($result)) {

$result = $this->_dbLink->query("UPDATE {$this->_sessionTable} SET value = {$session_data} WHERE sid = {$session_id}");

}

else{

$result = $this->_dbLink->query("INSERT INTO {$this->_sessionTable} (sid, value) VALUES ('{$session_id}', '{$session_data}')");

}

if($result){

return 0;

}

else{

return 1;

}

}

/**

* 销魂session

* @access public

* @param string $session_id session ID

* @return integer

*/

public function destroy($session_id) {

$result = $this->_dbLink->query("DELETE FROM {$this->_sessionTable} WHERE sid = '{$session_id}'");

if($result){

return 0;

}

else{

return 1;

}

}

/**

* 垃圾回收

* @access public

* @param string $maxlifetime session 最长生存时间

* @return integer

*/

public function gc($maxlifetime) {

$result = $this->_dbLink->query("DELETE FROM {$this->_sessionTable} WHERE UNIX_TIMESTAMP(expiration) 

if($result){

return 0;

}

else{

return 1;

}

}

}$dbLink = new mysqli("localhost", "root", "root", "test");

$sessionTable = "sessioninfo";

$handler = new MySessionHandler($dbLink, $sessionTable);

session_set_save_handler($handler);

session_start();

$_SESSION['name'] = "test";

echo $_SESSION["name"];

//session_destroy();

看完上述内容,你们掌握在PHP中怎么将session数据保持到数据库中的方法了吗?如果还想学到更多技能或想了解更多相关内容,欢迎关注亿速云行业资讯频道,感谢各位的阅读!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
毕业设计,基于SpringBoot+Vue+MySQL开发的纺织品企业财务管理系统,源码+数据库+毕业论文+视频演示 在如今社会上,关于信息上面的处理,没有任何一个企业或者个人会忽视,如何让信息急速传递,并且归档储存查询,采用之前的纸张记录模式已经不符合当前使用要求了。所以,对纺织品企业财务信息管理的提升,也为了对纺织品企业财务信息进行更好的维护,纺织品企业财务管理系统的出现就变得水到渠成不可缺少。通过对纺织品企业财务管理系统的开发,不仅仅可以学以致用,让学到的知识变成成果出现,也强化了知识记忆,扩大了知识储备,是提升自我的一种很好的方法。通过具体的开发,对整个软件开发的过程熟练掌握,不论是前期的设计,还是后续的编码测试,都有了很深刻的认知。 纺织品企业财务管理系统通过MySQL数据库与Spring Boot框架进行开发,纺织品企业财务管理系统能够实现对财务人员,员工,收费信息,支出信息,薪资信息,留言信息,报销信息等信息的管理。 通过纺织品企业财务管理系统对相关信息的处理,让信息处理变的更加的系统,更加的规范,这是一个必然的结果。已经处理好的信息,不管是用来查找,还是分析,在效率上都会成倍的提高,让计算机变得更加符合生产需要,变成人们不可缺少的一种信息处理工具,实现了绿色办公,节省社会资源,为环境保护也做了力所能及的贡献。 关键字:纺织品企业财务管理系统,薪资信息,报销信息;SpringBoot
session数据库的具体步骤如下: 1. 首先需要创建一个数据库表,用于存储session数据,可以创建一个名为`sessions`的表,包含以下字段: ``` session_id VARCHAR(255) PRIMARY KEY, session_data TEXT, session_expiry INT(11) ``` 2. 在php代码,需要通过`session_set_save_handler()`函数设置自定义session处理程序,以将session数据存储到数据库。具体代码如下: ``` // 自定义session处理程序 class DBSessionHandler { private $db; public function __construct($db) { $this->db = $db; session_set_save_handler( array($this, 'open'), array($this, 'close'), array($this, 'read'), array($this, 'write'), array($this, 'destroy'), array($this, 'gc') ); } public function open($savePath, $sessionName) { // 不需要执行任何操作 return true; } public function close() { // 不需要执行任何操作 return true; } public function read($sessionId) { $stmt = $this->db->prepare("SELECT session_data FROM sessions WHERE session_id = ?"); $stmt->execute(array($sessionId)); $result = $stmt->fetch(PDO::FETCH_ASSOC); return $result ? $result['session_data'] : ''; } public function write($sessionId, $sessionData) { $expiry = time() + ini_get('session.gc_maxlifetime'); $stmt = $this->db->prepare("REPLACE INTO sessions (session_id, session_data, session_expiry) VALUES (?, ?, ?)"); $stmt->execute(array($sessionId, $sessionData, $expiry)); return true; } public function destroy($sessionId) { $stmt = $this->db->prepare("DELETE FROM sessions WHERE session_id = ?"); $stmt->execute(array($sessionId)); return true; } public function gc($maxlifetime) { $stmt = $this->db->prepare("DELETE FROM sessions WHERE session_expiry < ?"); $stmt->execute(array(time())); return true; } } // 初始化自定义session处理程序 $handler = new DBSessionHandler(new PDO('mysql:host=localhost;dbname=mydb', 'username', 'password')); session_set_save_handler($handler, true); ``` 上述代码,`DBSessionHandler`类实现了php的`SessionHandlerInterface`接口,将session数据存储到`sessions`表。`session_set_save_handler()`函数用于设置自定义session处理程序,并将其注册到phpsession处理流程。 3. 最后,可以在php代码通过`session_start()`函数启动session处理程序,开始对session数据进行操作。 ``` session_start(); $_SESSION['username'] = 'John'; $_SESSION['email'] = 'john@example.com'; ``` 在上述代码,`$_SESSION`数组数据会被自动存储到`sessions`表。可以通过查询该表来获取session数据
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值