java操作Redis緩存設置過期時間的方法
關于Redis的概念和應用本文就不再詳解了,說一下怎么在java應用中設置過期時間。
在應用中我們會需要使用redis設置過期時間,比如單點登錄中我們需要隨機生成一個token作為key,將用戶的信息轉(zhuǎn)為json串作為value保存在redis中,通常做法是:
//生成tokenString token = UUID.randomUUID().toString();//把用戶信息寫入redisjedisClient.set(REDIS_USER_SESSION_KEY + ':' + token,JsonUtils.objectToJson(user));//設置session的過期時間 時間單位是秒jedisClient.expire(REDIS_USER_SESSION_KEY + ':' + token, 1800);
但這樣做可能會出現(xiàn)問題,比如多并發(fā)上面,設置值和過期時間用了兩步操作。可以將設置值和過期時間合并成一步操作,所以可以使用redis的設置值set的另外一個方法:
// NX是不存在時才set, XX是存在時才set, EX是秒,PX是毫秒jedisClient.set(key, value, 'NX', 'EX', expireSecond);
取值的時候使用:
@Override public Result getUserByToken(String token) { //根據(jù)token從redis中查詢用戶信息 String json = jedisClient.get(REDIS_USER_SESSION_KEY + ':' + token); //判斷是否為空 if (StringUtils.isBlank(json)) { return Result.build(400, '此session已經(jīng)過期,請重新登錄'); } //更新過期時間 jedisClient.expire(REDIS_USER_SESSION_KEY + ':' + token, 1800); //返回用戶信息 return Result.ok(JsonUtils.jsonToPojo(json, TbUser.class)); }
其他使用方法:
public void save(String key, String value, Long expireSecond) { boolean keyExist = jedisClient.exists(key); if (keyExist) { jedisCluster.del(key); } // NX是不存在時才set, XX是存在時才set, EX是秒,PX是毫秒 jedisClient.set(key, value, 'NX', 'EX', expireSecond);}
到此這篇關于java操作Redis緩存設置過期時間的方法的文章就介紹到這了,更多相關java 設置過期時間內(nèi)容請搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持好吧啦網(wǎng)!
相關文章:
1. php使用正則驗證密碼字段的復雜強度原理詳細講解 原創(chuàng)2. 淺談由position屬性引申的css進階討論3. ASP中實現(xiàn)字符部位類似.NET里String對象的PadLeft和PadRight函數(shù)4. 解析原生JS getComputedStyle5. ASP實現(xiàn)加法驗證碼6. CSS可以做的幾個令你嘆為觀止的實例分享7. 利用CSS3新特性創(chuàng)建透明邊框三角8. vue前端RSA加密java后端解密的方法實現(xiàn)9. JSP+Servlet實現(xiàn)文件上傳到服務器功能10. ASP動態(tài)網(wǎng)頁制作技術經(jīng)驗分享

網(wǎng)公網(wǎng)安備