php简单调用后端数据库,简易的PHP session数据库后端(Postgres)

一个开发环境有多个网站,需要使用不同的session,解决方案很多。不过这次也高大上一把,用数据库存,方便以后扩展。

首先是数据库的部分

--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 < current_timestamp - interval ‘30 days‘

$del_session$ language sql;

然后是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数据库的链接而已

原文:http://my.oschina.net/visualgui823/blog/290074

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值