redis学习(四) 登录和cookie缓存
生活随笔
收集整理的這篇文章主要介紹了
redis学习(四) 登录和cookie缓存
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
<redis實戰> 第二章
1.cookie緩存用戶信息的兩種方式
? ? ? ? ?每當我們登錄互聯網服務時,這些服務會使用cookie記錄我們的身份 .cookie由少量數據組成,網站會要求我們瀏覽器存儲這些數據,并在每次服務發送請求時將這些數據返回給服務. 對于用來登錄的cookie,有兩種常用的方式可以將登錄信息存儲到cookie里面:一種是簽名(sign)cookie,另一種是令牌(token)cookie
? ? ? ? ?簽名cookie通常會存儲用戶名,可能還有用戶id,用戶最后一次登錄成功的時間,以及網站覺得有用的其他信息.除了用戶的相關信息之外,簽名cookie還包含一個簽名,服務器可以使用這個簽名來驗證瀏覽器發送的信息是否未經改動(比如講cookie中的用戶名改成另外一個用戶)
? ? ? ? 令牌cookie會在cookie中存儲一串隨機字節作為令牌,服務器可以根據令牌 在數據庫中查找令牌擁有者. 隨著時間的推移,舊令牌被新令牌代替
?
2.使用令牌cookie(sign)存儲令牌信息
用戶在購買商品前,會瀏覽不同的商品
使用散列存儲登錄cookie令牌和已登錄用戶之間的關系(映射).
<?php$redis = new Redis(); $redis->connect('127.0.0.1',6379);/*** 檢查用戶是否登錄* @param $redis* @param $token* @return mixed*/ function check_token($redis,$token) {//根據給定的令牌來查找與之對應的用戶,并在用戶已經登錄的情況下返回用戶的idreturn $redis->hget('login:',$token); }$redis->zAdd($key,$score,$value);/*** 更新令牌* @param $redis* @param $token* @param $user* @param $item*/ function update_token($redis,$token,$user,$item) {//用戶每次瀏覽頁面的時候,程序對存儲在散列里面的信息進行更新,并將用戶的令牌和當前時間戳添加到最近登錄用戶的有序集合里面$redis->hSet('login:',$token,$user); //維持令牌與登錄用戶之間的(關系)映射$redis->zAdd('recent:',time(),$token); //記錄令牌最后一次出現的時間if ($item){$redis->zadd('viewd:'.$token,time(),$item); //記錄用戶瀏覽過的商品$redis->zRemRangeByRank('viewed:'.$token,0,-26); //移除舊的記錄,只保留用戶最近瀏覽過的25個商品}}//守護進程方式運行 //定時任務(cron)運行 /*** 定期清理舊的會話數據* @param $redis*/ function clean_sessions($redis) {$quit = false;$limit = 1000000;while (!$quit){$size = $redis->zCard('recent:'); //找出當前已有令牌的數量if ($size < $limit) // 令牌未超過限制,休眠并在之后重新檢查{sleep(1);continue;}else{$quit = true;}}$end_index = min($size-$limit,100);$token = $redis->zRange('recent:',0,$end_index-1); //獲取需要移除令牌的idforeach ($token as $value){$session_key [] = $value['viewed:'.$token]; //給被刪除的令牌構建鍵名}$redis->delete($session_key);$redis->del('login',$value);$redis->zrem('recent:',$value); //移除最舊的令牌}?
?
?
?
?
總結
以上是生活随笔為你收集整理的redis学习(四) 登录和cookie缓存的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: PHP 利用 curl 发送 post
- 下一篇: redis学习(五) redis实现购物