龙空技术网

Spring session 获取当前账户登录数的实例代码

Deities冥 98

前言:

如今各位老铁们对“jsp获取session中的值”大体比较讲究,兄弟们都需要知道一些“jsp获取session中的值”的相关知识。那么小编在网络上网罗了一些有关“jsp获取session中的值””的相关资讯,希望各位老铁们能喜欢,各位老铁们快快来了解一下吧!

Spring session 获取当前账户登录数

一、登录校验成功时,向session加入关键信息,代码如下:

session.setAttribute(FindByIndexNameSessionRepository.PRINCIPAL_NAME_INDEX_NAME, userId);

二、获取当前session账户的登录数,及有多少个客户端使用了当前账户登录:

@Autowiredprivate RedisOperationsSessionRepository sessionRepository;

public Integer fetchSameLoginNum(HttpServletRequest request) {int result = 0;HttpSession session = request.getSession();if (session != null) {String userId = (String) session.getAttribute(FindByIndexNameSessionRepository.PRINCIPAL_NAME_INDEX_NAME);if (StringUtils.isNotEmpty(userId)) {Map<String, ? extends Session> nameAndIndexValue = sessionRepository.findByIndexNameAndIndexValue(FindByIndexNameSessionRepository.PRINCIPAL_NAME_INDEX_NAME, userId);result = nameAndIndexValue.size();}}return result;}补充:解决同一浏览器登录多个账户session共享问题

首先session是同一PC同一浏览器共享的.比如如下代码:

public void doPost(HttpServletRequest request, HttpServletResponse response)throws ServletException, IOException{HttpSession hs = request.getSession();//存入sessionString user = request.getParameter("user");hs.setAttribute("user", user);response.sendRedirect("index.JSP");}

解决办法1:限制同一浏览器多个账户登录,方法是根据key获取session的值 session.getAttribute(key),判断这个结果是不是空,不是空,就说明已登录。

解决方法2:不同帐户共用一个session,将信息以(key,value)形式放入session,然后所有的请求都加上userid参数,所有从session中取数据出来都通过getXXByUserId。这种实现对现有框架改动较大,而且不仅仅是放在session中的用户信息需要根据byuserid来提取而是所有的会话里面的信息都要byuserid的来弄。故不建议采取这种做法。

标签: #jsp获取session中的值