听说可以把session存到数据库,这样可以设置多久失效都可以 再问下,PHP。INI中session.save_handler = files 一定要改为user才能把SESSION保存到数据库中吗? 解决方案 » 免费领取超大流量手机卡,每月29元包185G流量+100分钟通话, 中国电信官方发货 <?phperror_reporting(7);//这里设置的就是时间$SESS_LIFE = 900;function sess_open($save_path,$session_name) { sess_gc(0); return true;}function sess_close() { return true;}function sess_read($key) { global $DB,$db_prefix,$session,$onlineuser; $session = $DB->fetch_one_array("SELECT * FROM ".$db_prefix."session WHERE sessionid='$key'"); if (!empty($session) AND $session[expiry]>time()) { return $session[value]; } else { $onlineuser++; return ""; }}function sess_write($key,$val) { global $DB,$db_prefix,$SESS_LIFE,$pauserinfo,$session; $expiry = time()+$SESS_LIFE; $value = addslashes($val); $ipaddress = getip(); $useragent = $_SERVER[HTTP_USER_AGENT]; $REQUEST_URI = $_SERVER[REQUEST_URI]; if (empty($session) AND $key!=$session[key]) { $query = $DB->query("INSERT INTO ".$db_prefix."session (sessionid,expiry,value,userid,ipaddress,useragent,location,lastactivity) VALUES ('$key',$expiry,'$value','$pauserinfo[userid]','".addslashes($ipaddress)."','".addslashes($useragent)."','".addslashes($REQUEST_URI)."','".time()."')"); } else { $query = $DB->query("UPDATE ".$db_prefix."session SET expiry='$expiry', userid='$pauserinfo[userid]', value='$value', ipaddress='".addslashes($ipaddress)."', useragent='".addslashes($useragent)."', location='".addslashes($REQUEST_URI)."', lastactivity='".time()."' WHERE sessionid='$key'"); } if ($pauserinfo[userid]!=0) { if ((time()-$pnuserinfo[lastactivity])>$SESS_LIFE) { $DB->query("UPDATE ".$db_prefix."user SET lastvisit=lastactivity,lastactivity='".time()."' WHERE userid='$pauserinfo[userid]'"); } else { $DB->query("UPDATE ".$db_prefix."user SET lastactivity='".time()."' WHERE userid='$pauserinfo[userid]'"); } } return $query;}function sess_destroy($key) { global $DB,$db_prefix; return $DB->query("DELETE FROM ".$db_prefix."session WHERE sessionid='$key'");}function sess_gc($maxlifetime) { global $DB,$db_prefix; $query = $DB->query("DELETE FROM ".$db_prefix."session WHERE expiry<".time().""); return $DB->affected_rows();}session_set_save_handler( "sess_open", "sess_close", "sess_read", "sess_write", "sess_destroy", "sess_gc");@session_start();?> register_about(register_about) 再问下,PHP。INI中session.save_handler = files 一定要改为user才能把SESSION保存到数据库中吗?------------------------------------------------不用,在加了上面这段代码后,把session.auto_start = 1 改成session.auto_start = 0 求助 按需求mysql需要建什么表 mysql乱码怎么处理啊? 访问php页面变成下载了 各位大侠 在下利用Linux默认环境里的mailx发邮件没问题 我想输出html的邮件内容 关于ecshop的问题 求字符(.)的正确用法 求一完整全面的fckeditor使用方法或手册 帮帮忙吧!!急急急.php实现文本框只能输入数字和/的实现方法???? 日期显示为2005-08-02 17:33:48,我之想要2005-08-02 PHP4太奇怪了!(一个关于session的疑问) 最近网站mysql总是提示Too many connections 出钱购买控件。。大家来看看你是否有
error_reporting(7);
//这里设置的就是时间
$SESS_LIFE = 900;function sess_open($save_path,$session_name) {
sess_gc(0);
return true;
}function sess_close() {
return true;
}function sess_read($key) { global $DB,$db_prefix,$session,$onlineuser;
$session = $DB->fetch_one_array("SELECT * FROM ".$db_prefix."session WHERE sessionid='$key'");
if (!empty($session) AND $session[expiry]>time()) {
return $session[value];
} else {
$onlineuser++;
return "";
}}function sess_write($key,$val) {
global $DB,$db_prefix,$SESS_LIFE,$pauserinfo,$session;
$expiry = time()+$SESS_LIFE;
$value = addslashes($val); $ipaddress = getip();
$useragent = $_SERVER[HTTP_USER_AGENT];
$REQUEST_URI = $_SERVER[REQUEST_URI]; if (empty($session) AND $key!=$session[key]) {
$query = $DB->query("INSERT INTO ".$db_prefix."session (sessionid,expiry,value,userid,ipaddress,useragent,location,lastactivity)
VALUES ('$key',$expiry,'$value','$pauserinfo[userid]','".addslashes($ipaddress)."','".addslashes($useragent)."','".addslashes($REQUEST_URI)."','".time()."')");
} else {
$query = $DB->query("UPDATE ".$db_prefix."session SET
expiry='$expiry',
userid='$pauserinfo[userid]',
value='$value',
ipaddress='".addslashes($ipaddress)."',
useragent='".addslashes($useragent)."',
location='".addslashes($REQUEST_URI)."',
lastactivity='".time()."'
WHERE sessionid='$key'");
}
if ($pauserinfo[userid]!=0) {
if ((time()-$pnuserinfo[lastactivity])>$SESS_LIFE) {
$DB->query("UPDATE ".$db_prefix."user SET lastvisit=lastactivity,lastactivity='".time()."' WHERE userid='$pauserinfo[userid]'");
}
else {
$DB->query("UPDATE ".$db_prefix."user SET lastactivity='".time()."' WHERE userid='$pauserinfo[userid]'");
}
}
return $query;
}function sess_destroy($key) {
global $DB,$db_prefix;
return $DB->query("DELETE FROM ".$db_prefix."session WHERE sessionid='$key'");
}function sess_gc($maxlifetime) {
global $DB,$db_prefix;
$query = $DB->query("DELETE FROM ".$db_prefix."session WHERE expiry<".time()."");
return $DB->affected_rows();
}session_set_save_handler(
"sess_open",
"sess_close",
"sess_read",
"sess_write",
"sess_destroy",
"sess_gc");@session_start();?>