我为什么不使用session_PHP教程
在考虑session的问题上,我最终放弃了session: 最后我选择了myql的heap表来处理session,并且把session处理和online在线用户统计结合起来。 下面给出代码为我的一个实例(没提供其他的细节了,具体使用要相应修改) `sid` char( 32 ) NOT NULL ,
1、原本的session是使用文件来管理的。文件系统的好坏直接影响session的性能,尤其当有几K人同时在线的时候,尤其突出。解决方法有两个:数据库和文件(使用哈希路径)。
2、原有session的扩展性和可控制性不好。不利于结合我现有的系统。
3、在选用数据库的时候,我并没有选择sqlite,上次我测试sqlite效率在win xp上效率没有想象中的好。
/**
* 处理在线用户和对session的模拟
* CREATE TABLE `webqq_session` (
`uid` mediumint( 8 ) NOT NULL ,
`username` char( 80 ) NOT NULL ,
`ismember` tinyint( 1 ) NOT NULL ,
`logintime` int( 10 ) NOT NULL ,
`activetime` int( 10 ) NOT NULL ,
PRIMARY KEY ( `sid` )
) ENGINE = HEAP DEFAULT CHARSET = gb2312
* @author:feifengxlq
* @since:2006-10-23
* @copyright:http://www.phpobject.net
* 注意:这个文件的使用必须和其他文件结合:比如对cookid的过滤,一些基本函数和数据库操作类
*/
class session
{
var $mysql;
var $cookie_id=webqq_sid;
var $session=array();
var $max_time=1200;//默认最大时间为20分钟
function __construct()
{
$this->mysql=new module(TB_PREX._session);//需要外部支持
$this->start();
}
function start()
{
if(empty($_COOKIE[$this->cookie_id]))
{
//初始化session
$this->create();
}else{
//cookie已经存在,检查是否存在数据库中
$sid=$_COOKIE[$this->cookie_id];
if($this->mysql->detail(where sid=.$sid.))
{
//存在数据库中
$row[activetime]=time();
$this->mysql->update($row,where sid=.$sid.);
$this->session=$this->mysql->detail(where sid=.$sid.);
}else{
//不存在数据库中
$this->create();
}
}
//删除数据库中不在线的用户
$this->mysql->delete(where activetime+.$this->max_time.<.time> }
function register($name,$value,$update=false)
{
if(array_key_exists($name,$this->session)){
$this->session[$name]=$value;
}
if($update)$this->update();
}
function registry($name=)
{
if(empty($name)) return $this->session;
if(array_key_exists($name,$this->session)){
return $this->session[$name];
}
}
//更新数据库里面的session信息
function update()
{
$row[uid]=$this->session[uid];
$row[username]=$this->session[username];
$row[ismember]=$this->session[ismember];
$row[logintime]=$this->session[logintime];
$row[activetime]=$this->session[activetime];
$this->mysql->update($row,where sid=.$this->session[sid].);
}
/*-------------------以下为私有方法------------------------------------------------------**/
function create()
{
$nowtime=time();
$sid=md5(0.$nowtime.getip());//需要预先定义好getip()函数:获取客户的IP地址
setcookie($this->cookie_id,$sid,$nowtime+3600*24);//默认24小时
$row[sid]=$sid;
$row[uid]=0;
$row[username]=guest;
$row[ismember]=0;
$row[logintime]=$nowtime;
$row[activetime]=$nowtime;
$this->mysql->add($row);//写入数据库
$this->session=$row;
}
}
?>

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

热门话题

关于Flex布局中紫色斜线区域的疑问在使用Flex布局时,你可能会遇到一些令人困惑的现象,比如在开发者工具(d...

H5页面需要持续维护,这是因为代码漏洞、浏览器兼容性、性能优化、安全更新和用户体验提升等因素。有效维护的方法包括建立完善的测试体系、使用版本控制工具、定期监控页面性能、收集用户反馈和制定维护计划。

JavaScript 是否可在无 HTML5 环境下运行?JavaScript 引擎自身可独立运行。在浏览器环境中运行 JavaScript 依赖 HTML5,因其提供加载和执行代码所需的标准化环境。HTML5 提供的 API 和特性对现代 JavaScript 框架和库至关重要。离开 HTML5 环境,许多 JavaScript 功能难以实现或无法实现。

在Safari中使用自定义样式表的问题探讨今天我们来探讨一个关于Safari浏览器的自定义样式表应用问题。前端新手...

H5 页面制作的优势包括:轻量级体验,加载速度快,提升用户留存率。跨平台兼容性,无需针对不同平台适配,提升开发效率。灵活性和动态更新,无需审核,便于内容修改和更新。成本效益,开发成本比原生 App 低。

无法以 root 身份登录 MySQL 的原因主要在于权限问题、配置文件错误、密码不符、socket 文件问题或防火墙拦截。解决方法包括:检查配置文件中 bind-address 参数是否正确配置。查看 root 用户权限是否被修改或删除,并进行重置。验证密码是否准确无误,包括大小写和特殊字符。检查 socket 文件权限设置和路径。检查防火墙是否阻止了 MySQL 服务器的连接。

Bootstrap Table 乱码通常是因为页面编码与表格数据编码不一致。要解决此问题,需要确保它们一致,具体步骤包括:检查页面和表格数据编码,设置页面编码,验证编码。如果使用 UTF-8,服务器也应支持。无法解决时,可尝试使用 JavaScript 编码库。

如何在element-plus中正确使用类名样式?在使用element-plus的过程中,很多开发者会遇到一个问题:为什么在自己的...
