日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

優化使用mysql存儲session

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

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

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

暫時給出代碼,不具體解釋。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 = '';//當前時間 private $_model = null;//數據庫操作模型 private $_expiry = 1200;//session有效時間 private $_domain = '';//session的作用域 protected $isNew = 0;//判定操作動作 0 更新 1 增加 protected $session = array();//對應的一條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); }}?>

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

標簽: MySQL 數據庫
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
亚洲色图网站| 神马日本精品| 亚洲美洲欧洲综合国产一区 | 日本不卡一二三区黄网| 亚洲中午字幕| 亚洲视频国产| 亚洲精品影院在线观看| 一区二区国产在线| 亚洲不卡视频| 国产日韩欧美在线播放不卡| 欧美黄页在线免费观看| 国产一区二区三区四区五区 | 成人国产精选| 97精品一区| 在线看片福利| 久久国产中文字幕| 红桃视频欧美| 石原莉奈在线亚洲二区| 亚洲精品在线国产| 日韩中出av| 久久激情五月激情| 久久精品人人| 精精国产xxxx视频在线播放| 91精品91| 午夜亚洲福利| 久久精品国产网站| 久久精品亚洲欧美日韩精品中文字幕| 久久网站免费观看| 一区二区三区午夜视频| 日韩精品一区二区三区中文| 免费一级欧美在线观看视频 | 综合激情网站| 欧美a在线观看| 欧美久久天堂| 99视频在线精品国自产拍免费观看| 亚洲精品大片| 成人一区而且| 国产精品三上| 国产九一精品| 久久国产免费| 午夜在线视频观看日韩17c| 亚洲1区在线| 福利视频一区| 免费人成精品欧美精品| 国产精品久久久久久模特| 日韩天堂在线| 亚洲精品系列| 国产精品久久久久av电视剧| 亚洲精选久久| 国产一区二区视频在线看| av不卡在线看| 久久精品福利| 香蕉成人久久| 国产一区丝袜| 亚洲小说春色综合另类电影| 国产一区二区三区四区五区传媒 | 日韩欧美中文字幕在线视频| 国产精品99一区二区三区| 免费国产自线拍一欧美视频| 精品视频在线你懂得| 亚洲欧美久久| 色综合五月天| 日韩成人av影视| 亚洲视频综合| 欧美国产精品| 免费在线视频一区| 岛国av在线网站| 日韩激情av在线| 欧美gv在线| 日韩高清二区| 激情婷婷综合| 国产第一亚洲| 91精品日本| 黄色精品网站| 久久影院午夜精品| 欧美日本不卡| 亚洲激情二区| 亚洲精品福利电影| 日韩av中文字幕一区| 久久久影院免费| 欧美极品一区二区三区| 丝袜美腿成人在线| 精品日韩视频| 精品一区二区三区亚洲| 国产农村妇女精品一二区| аⅴ资源天堂资源库在线| 国产欧美亚洲精品a| 999久久久精品国产| 欧美极品中文字幕| 日韩在线观看中文字幕| 韩日一区二区三区| 中文字幕在线高清| 国产剧情一区| 日本综合视频| 免费人成黄页网站在线一区二区 | 亚洲香蕉久久| 亚洲精品一区二区在线看| 久久99影视| 欧美日一区二区三区在线观看国产免| 亚洲欧美日韩国产一区| 欧美1级日本1级| 成人精品中文字幕| 亚洲精品**中文毛片| 精品国产欧美日韩一区二区三区| 国产欧美日韩精品高清二区综合区| 亚洲精品日韩久久| 丝袜美腿亚洲一区| 亚洲精品va| 国产中文一区| 日韩电影免费在线观看| 韩国女主播一区二区三区| 国产精品一区二区av交换| 亚洲人成毛片在线播放女女| 狠狠干综合网| 国产一区91| 国产亚洲精品v| 久久av一区| 中文视频一区| 蜜臀av国产精品久久久久| 视频在线观看国产精品| 老鸭窝亚洲一区二区三区| 久久亚洲一区| 在线免费观看亚洲| 在线视频亚洲欧美中文| 免费日本视频一区| 亚洲视频电影在线| 亚洲1区在线观看| 天堂久久av| 日本电影久久久| 青青国产精品| 国产精品调教| 久久精品免费看| 91亚洲成人| 日韩精品第一区| 亚洲手机在线| 首页国产欧美久久| 日韩精品a在线观看91| 欧美中文一区| 久久99视频| 黄色精品视频| 成人在线网站| 国产精品毛片在线看| av不卡在线| 日韩在线观看一区二区三区| 国产精品视频一区二区三区 | 国产精品一区二区三区美女| 精品视频自拍| 国产主播一区| 亚洲人妖在线| 久久99青青| 99精品在线| 亚洲我射av| 精品一区视频| 久久国产中文字幕| 亚洲欧美日韩精品一区二区| 日韩欧美高清一区二区三区| 精品亚洲成人| 国产精品99免费看| 亚洲精品影院在线观看| 久久不见久久见中文字幕免费| 一区二区精品伦理...| 国产婷婷精品| 国产精品最新| 久久九九精品| 日韩欧美2区| 国内揄拍国内精品久久| 欧美亚洲国产激情| 蜜臀av在线播放一区二区三区 | 久久人人精品| 蜜桃视频在线观看一区| 欧美在线看片| 国产第一亚洲| 国产亚洲在线| 欧美aa在线视频| 美女久久久久| 日本免费新一区视频| 国产videos久久| 亚洲综合不卡| 精品伊人久久| 午夜在线观看免费一区| 免费在线成人| 国产模特精品视频久久久久| 欧美午夜网站| 久久久夜精品| 清纯唯美亚洲综合一区| 激情亚洲影院在线观看| 影音先锋久久精品| 色婷婷色综合| 五月亚洲婷婷 | 亚洲三级网站| 超碰在线99| 少妇精品久久久| 中文字幕系列一区| 日韩精品成人| 99久久亚洲精品蜜臀| 日本欧美韩国一区三区| 日本蜜桃在线观看视频| 日韩久久99| 欧美一区二区性| 欧美精品二区|