之前寫過兩篇文章《自定義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;