java操作Redis緩存設置過期時間的方法
關于Redis的概念和應用本文就不再詳解了,說一下怎么在java應用中設置過期時間。
在應用中我們會需要使用redis設置過期時間,比如單點登錄中我們需要隨機生成一個token作為key,將用戶的信息轉為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);
但這樣做可能會出現問題,比如多并發上面,設置值和過期時間用了兩步操作。可以將設置值和過期時間合并成一步操作,所以可以使用redis的設置值set的另外一個方法:
// NX是不存在時才set, XX是存在時才set, EX是秒,PX是毫秒jedisClient.set(key, value, 'NX', 'EX', expireSecond);
取值的時候使用:
@Override public Result getUserByToken(String token) { //根據token從redis中查詢用戶信息 String json = jedisClient.get(REDIS_USER_SESSION_KEY + ':' + token); //判斷是否為空 if (StringUtils.isBlank(json)) { return Result.build(400, '此session已經過期,請重新登錄'); } //更新過期時間 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 設置過期時間內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!
相關文章: