电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術(shù)文章
文章詳情頁

優(yōu)化使用mysql存儲session

瀏覽:150日期:2023-10-26 19:38:49

之前寫過兩篇文章《自定義SESSION(二)——數(shù)據(jù)庫保存》和《我為什么不使用session》 但后來發(fā)現(xiàn)都有問題。前者處理在實際中幾乎沒什么用處,而且session回收還得自己另外處理。后者頻繁的操作數(shù)據(jù)庫,打來了很大的性能問題。

這兩天仔細(xì)考慮下,大致給出一個方案,但還沒有具體詳細(xì)的測試。 1、session處理和統(tǒng)計結(jié)合起來。同時游客也都有記錄。 2、完全使用數(shù)據(jù)庫和cookie來模擬session的功能。 3、用戶的對session的操作都盡量保證在一條sql語句完成。不用到session的時候,絕對不多一條查詢。 4、為了效率起見,session的回收沒有集成進(jìn)來,但提供了接口,可以調(diào)用實現(xiàn)。

暫時給出代碼,不具體解釋。sql

CREATE TABLE `*****_session` (`sid` char(32) NOT NULL,`uid` int(10) NOT NULL,`username` char(32) NOT NULL,`usertype` tinyint(1) NOT NULL,`activetime` int(10) NOT NULL,`expiry` int(10) NOT NULL,`ip` char(15) NOT NULL,`url` char(80) NOT NULL,`value` char(255) NOT NULL,PRIMARY KEY; (`sid`)) ENGINE=MEMORY DEFAULT CHARSET=utf8;

php代碼

<?class session{ private $_sessionPrex= '';//session的前綴 private $_time = '';//當(dāng)前時間 private $_model = null;//數(shù)據(jù)庫操作模型 private $_expiry = 1200;//session有效時間 private $_domain = '';//session的作用域 protected $isNew = 0;//判定操作動作 0 更新 1 增加 protected $session = array();//對應(yīng)的一條session記錄 public function __construct($options){ $this->_setOptions($options); if(empty($this->_time))$this->_time = time(); $this->session['activetime'] = $this->_time; } public function start(){ $this->_getSid(); } public function set($key,$value){ if(in_array($key,array('uid','username','usertype','url','expiry'))){ if($key == 'expiry'){ $this->_setCookie($this->_sessionPrex.'_sid',$this->session['sid'],$value); $this->_setCookie($this->_sessionPrex.'_uid',$this->session['uid'],$value); } $this->session[$key] = $value; }else{ $other = $this->session['value']; $other[$key] = $value; $this->session['value'] = $other; } } public function get($key){ if(in_array($key,array('uid','username','usertype','url','expiry'))){ return $this->session[$key]; }else{ if(isset($this->session['value'][$key])){ return $this->session['value'][$key]; } return null; } } public function gc($file,$time = 1200){ $lasttime = file_get_contents($file); if($lasttime + $time<$this->_time){ file_put_contents($file,$this->_time); return $this->_model->delete('activetime+expiry<'.$this->_time); } } public function destroy(){ $this->session['uid'] = 0; $this->session['username'] = ''; $this->session['usertype'] = -1; $this->session['expiry'] = $this->_expiry; $this->session['value'] = array(); $this->_setCookie($this->_sessionPrex.'_sid',$this->session['sid'],$this->_expiry); $this->_setCookie($this->_sessionPrex.'_uid',$this->session['uid'],$this->_expiry); } public function __destruct(){ $this->_save(); } private function _save(){ $dbSession = $this->session; $dbSession['value'] = serialize($dbSession['value']); if(strlen($dbSession['value'])>255)$this->_error('session->value is too long!'); if($this->isNew == 1){ //增加 $this->_model->insert($dbSession); }else{ //更新 $sid = $dbSession['sid']; $this->_model->update(array_slice($dbSession,1),'sid=''.$sid.'''); } } private function _getSession($sid){ $dbSession = $this->_model->detail('sid = ''.$sid.'''); if(!$dbSession)return false; $dbSession['value'] = unserialize($dbSession['value']); $this->session = array_merge($dbSession,$this->session) return true; } private function _getSid(){ $sid = strip_tags($_COOKIE[$this->_sessionPrex.'_sid']); if(strlen($sid)==32){ if($this->_getSession($sid)){ return true; } }else{ $sid = md5(time().mt_rand(1000,10000)); $this->_setCookie($this->_sessionPrex.'_sid',$sid); } $this->_setCookie($this->_sessionPrex.'_uid',0); $this->session = array( 'uid' => 0, 'username' => '', 'usertype' => -1, 'activetime' => $this->_time, 'ip' => $this->_getip(), 'url' => strip_tags($_SERVER['REQUEST_URI']), 'expiry' =>$this->_expiry, 'value' => array() ); $this->isNew = 1; $this->session['sid'] = $sid; } private function _setCookie($name,$value,$expiry=0){ if(empty($expiry))$expiry = $this->_expiry; if(empty($this->_domain)){ setcookie($name,$value,$this->_time + $expiry,'/'); }else{ setcookie($name,$value,$this->_time + $expiry,'/',$this->_domain); } } private function _getip(){ return getip(); } private function _setOptions($options){ foreach ($options as $key=>$value){ if(in_array($key,array('sessionPrex','time','model','expiry','domain'))){ $key = '_'.$key; $this->$key = $value; } } } private function _error($msg){ throw new Phpbean_Exception($msg); }}?>

(注意,該代碼不能直接使用,本文主要是提供一種思路)

標(biāo)簽: MySQL 數(shù)據(jù)庫
主站蜘蛛池模板: TPE_TPE热塑性弹性体_TPE原料价格_TPE材料厂家-惠州市中塑王塑胶制品公司- 中塑王塑胶制品有限公司 | 电动手术床,医用护理床,led手术无影灯-曲阜明辉医疗设备有限公司 | 泰国专线_泰国物流专线_广州到泰国物流公司-泰廊曼国际 | 济南保安公司加盟挂靠-亮剑国际安保服务集团总部-山东保安公司|济南保安培训学校 | 西安展台设计搭建_西安活动策划公司_西安会议会场布置_西安展厅设计西安旭阳展览展示 | 混合气体腐蚀试验箱_盐雾/硫化氢/气体腐蚀试验箱厂家-北京中科博达 | 废气处理_废气处理设备_工业废气处理_江苏龙泰环保设备制造有限公司 | 继电器模组-IO端子台-plc连接线-省配线模组厂家-世麦德 | 天津力值检测-天津管道检测-天津天诚工程检测技术有限公司 | 空冷器|空气冷却器|空水冷却器-无锡赛迪森机械有限公司[官网] | 钢格栅板_钢格板网_格栅板-做专业的热镀锌钢格栅板厂家-安平县迎瑞丝网制造有限公司 | 南溪在线-南溪招聘找工作、找房子、找对象,南溪综合生活信息门户! | 南京技嘉环保科技有限公司-杀菌除臭剂|污水|垃圾|厕所|橡胶厂|化工厂|铸造厂除臭剂 | 浙江富广阀门有限公司| 培训中心-海南香蕉蛋糕加盟店技术翰香原中心官网总部 | 标准光源箱|对色灯箱|色差仪|光泽度仪|涂层测厚仪_HRC大品牌生产厂家 | 一体化隔油提升设备-餐饮油水分离器-餐厨垃圾处理设备-隔油池-盐城金球环保产业发展有限公司 | 富森高压水枪-柴油驱动-养殖场高压清洗机-山东龙腾环保科技有限公司 | 同步带轮_同步带_同步轮_iHF合发齿轮厂家-深圳市合发齿轮机械有限公司 | 深圳美安可自动化设备有限公司,喷码机,定制喷码机,二维码喷码机,深圳喷码机,纸箱喷码机,东莞喷码机 UV喷码机,日期喷码机,鸡蛋喷码机,管芯喷码机,管内壁喷码机,喷码机厂家 | 玉米加工设备,玉米深加工机械,玉米糁加工设备.玉米脱皮制糁机 华豫万通粮机 | 合肥地磅_合肥数控切割机_安徽地磅厂家_合肥世佳电工设备有限公司 | led冷热冲击试验箱_LED高低温冲击试验箱_老化试验箱-爱佩百科 | 空气能暖气片,暖气片厂家,山东暖气片,临沂暖气片-临沂永超暖通设备有限公司 | 苏州伊诺尔拆除公司_专业酒店厂房拆除_商场学校拆除_办公楼房屋拆除_家工装拆除拆旧 | 肉嫩度仪-凝胶测试仪-国产质构仪-气味分析仪-上海保圣实业发展有限公司|总部 | 英思科GTD-3000EX(美国英思科气体检测仪MX4MX6)百科-北京嘉华众信科技有限公司 | 气象监测系统_气象传感器_微型气象仪_气象环境监测仪-山东风途物联网 | 施工围挡-施工PVC围挡-工程围挡-深圳市旭东钢构技术开发有限公司 | 卡诺亚轻高定官网_卧室系统_整家定制_定制家居_高端定制_全屋定制加盟_定制家具加盟_定制衣柜加盟 | 车载加油机品牌_ 柴油加油机厂家| 钢绞线万能材料试验机-全自动恒应力两用机-混凝土恒应力压力试验机-北京科达京威科技发展有限公司 | 艾乐贝拉细胞研究中心 | 国家组织工程种子细胞库华南分库 | 锂电混合机-新能源混合机-正极材料混料机-高镍,三元材料混料机-负极,包覆混合机-贝尔专业混合混料搅拌机械系统设备厂家 | 制氮设备_PSA制氮机_激光切割制氮机_氮气机生产厂家-苏州西斯气体设备有限公司 | 【MBA备考网】-2024年工商管理硕士MBA院校/报考条件/培训/考试科目/提前面试/考试/学费-MBA备考网 | 东莞喷砂机-喷砂机-喷砂机配件-喷砂器材-喷砂加工-东莞市协帆喷砂机械设备有限公司 | 东莞市海宝机械有限公司-不锈钢分选机-硅胶橡胶-生活垃圾-涡电流-静电-金属-矿石分选机 | 污水处理设备维修_污水处理工程改造_机械格栅_过滤设备_气浮设备_刮吸泥机_污泥浓缩罐_污水处理设备_污水处理工程-北京龙泉新禹科技有限公司 | 检验科改造施工_DSA手术室净化_导管室装修_成都特殊科室建设厂家_医疗净化工程公司_四川华锐 | 矿用履带式平板车|探水钻机|气动架柱式钻机|架柱式液压回转钻机|履带式钻机-启睿探水钻机厂家 |