文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

SpringSession怎么通过Redis统计在线用户数量

2023-07-05 22:49

关注

这篇“SpringSession怎么通过Redis统计在线用户数量”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“SpringSession怎么通过Redis统计在线用户数量”文章吧。

因为系统原先的逻辑是使用Spring Session加上Redis做的会话共享实现的单点登录,登录之后会在session设置一个key值表示用户已经登录过,同时重写HttpServletRequestWrapper 设置remoteUser数据值

class RemoteUserRequestWrapper extends HttpServletRequestWrapper {String userCode;RemoteUserRequestWrapper(HttpServletRequest request) {super(request);this.userCode = (String) request.getSession().getAttribute(org.apache.commons.lang3.StringUtils.isBlank(sessionKeyName)?DEFAULT_SESSION_KEY_NAME:sessionKeyName);}@Overridepublic String getRemoteUser() {return userCode;}}

Spring Session缓存在redis里的数据

SpringSession怎么通过Redis统计在线用户数量

这个ssoLoginUser key是自己登录时候设置的,根据业务修改,经过测试,在登出系统时候,session设置过期获取removeAttribute不能清redis里的key数据,所以只能在登出系统逻辑加上:

Set<String> keys = RedisUtils.redisTemplate.keys("spring:session:sessions:*");for(String key : keys){if(key.indexOf("expires")==-1){String s = (String)RedisUtils.redisTemplate.opsForHash().get(key, "sessionAttr:ssoLoginUser");if(request.getRemoteUser().equals(s)) {logger.info("loginusername:{}",s)RedisUtils.redisTemplate.opsForHash().delete(key, "sessionAttr:ssoLoginUser");}}}

进行数据统计:

  List<Map<String,Object>> list = new ArrayList<Map<String, Object>>();  List<Map<String,Object>> data = new ArrayList<Map<String, Object>>();  Set<String> keys = redisTemplate.keys("spring:session:sessions:*");  for(String key : keys){      if(key.indexOf("expires")==-1){          String s = (String)redisTemplate.opsForHash().get(key, "sessionAttr:ssoLoginUser");          if(StringUtils.isNotBlank(s)) {              System.out.println(s);              Map<String,Object> map = new HashMap<String,Object>(16);              map.put("usercode", s);              list.add(map);          }      }  }  return list;

pom.xml:

<dependency><groupId>org.springframework.session</groupId><artifactId>spring-session-data-redis</artifactId><version>1.2.2.RELEASE</version><type>pom</type></dependency><dependency><groupId>biz.paluch.redis</groupId><artifactId>lettuce</artifactId><version>3.5.0.Final</version></dependency>

RedisUtils.java:

package com.common.utils.redis;import org.springframework.data.redis.core.RedisTemplate;import org.springframework.web.context.ContextLoader;import org.springframework.web.context.WebApplicationContext;import java.util.Collection;import java.util.List;import java.util.Map;import java.util.concurrent.TimeUnit;public class RedisUtils {private RedisUtils() {}@SuppressWarnings("unchecked")public static RedisTemplate<String, Object> redisTemplate =ContextLoader.getCurrentWebApplicationContext().getBean(RedisTemplate.class);public static boolean expire(final String key, final long timeout) {return expire(key, timeout, TimeUnit.SECONDS);}public static boolean expire(final String key, final long timeout, final TimeUnit unit) {Boolean ret = redisTemplate.expire(key, timeout, unit);return ret != null && ret;}public static boolean del(final String key) {redisTemplate.delete(key);return true;}public static long del(final Collection<String> keys) {redisTemplate.delete(keys);return 0;}public static void set(final String key, final Object value) {redisTemplate.opsForValue().set(key, value, 1, TimeUnit.MINUTES);}// 存储普通对象操作public static void set(final String key, final Object value, final long timeout) {redisTemplate.opsForValue().set(key, value, timeout, TimeUnit.SECONDS);}public static Object get(final String key) {return redisTemplate.opsForValue().get(key);}// 存储Hash操作public static void hPut(final String key, final String hKey, final Object value) {redisTemplate.opsForHash().put(key, hKey, value);}public static void hPutAll(final String key, final Map<String, Object> values) {redisTemplate.opsForHash().putAll(key, values);}public static Object hGet(final String key, final String hKey) {return redisTemplate.opsForHash().get(key, hKey);}public static List<Object> hMultiGet(final String key, final Collection<Object> hKeys) {return redisTemplate.opsForHash().multiGet(key, hKeys);}// 存储Set相关操作public static long sSet(final String key, final Object... values) {Long count = redisTemplate.opsForSet().add(key, values);return count == null ? 0 : count;}public static long sDel(final String key, final Object... values) {Long count = redisTemplate.opsForSet().remove(key, values);return count == null ? 0 : count;}// 存储List相关操作public static long lPush(final String key, final Object value) {Long count = redisTemplate.opsForList().rightPush(key, value);return count == null ? 0 : count;}public static long lPushAll(final String key, final Collection<Object> values) {Long count = redisTemplate.opsForList().rightPushAll(key, values);return count == null ? 0 : count;}public static long lPushAll(final String key, final Object... values) {Long count = redisTemplate.opsForList().rightPushAll(key, values);return count == null ? 0 : count;}public static List<Object> lGet(final String key, final int start, final int end) {return redisTemplate.opsForList().range(key, start, end);}}

以上就是关于“SpringSession怎么通过Redis统计在线用户数量”这篇文章的内容,相信大家都有了一定的了解,希望小编分享的内容对大家有帮助,若想了解更多相关的知识内容,请关注编程网行业资讯频道。

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯