美文网首页
Http - Session篇

Http - Session篇

作者: 鱼猫大脚 | 来源:发表于2020-12-09 15:12 被阅读0次

    HTTP是无状态协议,它本身不能以状态来区分和管理请求和响应。当服务端需要记录用户的状态时,就需要某种机制来记录和识别。

    会话(Session) 跟踪就是Web程序中常用的技术,用来跟踪用户的整个会话。常用的会话跟踪技术是CookieSession,本篇介绍Session

    Session

    Session技术是服务端的解决方案。使用一种类似散列表的结构来保存信息;

    Session Id

    当程序需要为某个客户端的请求创建一个Session的时候,首先检查客户端的请求里是否已包含了Session的标识,一般称为Session Id,有则按此Session Id来检索Session信息,否则新建一个。

    客户端通常有如下几种方式来记录Session Id

    1. 借助Cookie来记录;
    2. 使用URL重写;即把Session Id直接附加在Url后面,如: http://your.url?jsessionid=session_id_value
    3. 表单隐藏域;即在页面上添加一个隐藏字段,在表单提交时发送给服务端。

    Session时效

    由于使用不同的客户端技术保存Session Id,他们的失效时间也不一样,通常在页面关闭浏览器关闭,或者Cookie失效时,Session Id丢失,导致无法检索到旧的Session,从而造成对Session时效的误解。

    而其实,最终Session的时效取决于服务端的实现。只要服务端Session还未失效,就算客户端重启了电脑,你把Session Id背下来发给服务端,服务端还是会认的嘛。

    操作Session

    Java Servlet为例:

    创建Session

      @PostMapping("/sessionInfo")
      public void postSessionInfo(HttpServletRequest request, String userName) {
          HttpSession session = request.getSession();
          // 设置:userName
          session.setAttribute("userName", userName);
          // 设置:过期时间(秒)
          session.setMaxInactiveInterval(30*60);
      }
    

    获取Session信息

      @GetMapping("/sessionInfo")
      public void getSessionInfo(HttpServletRequest request) {
          HttpSession session = request.getSession();
          // 获取:userName
          String userName = (String) session.getAttribute("userName");
          // 获取:session的创建时间
          long creationTime = session.getCreationTime();
          // 获取:上次与服务器交互时间
          long lastAccessedTime = session.getLastAccessedTime();
          // 获取: sessionId
          String id = session.getId();
          // 获取:session过期时间
          int timeout = session.getMaxInactiveInterval();
    
          // 销毁session
          session.invalidate();
      }
    

    本文完

    相关文章

      网友评论

          本文标题:Http - Session篇

          本文链接:https://www.haomeiwen.com/subject/hpuhgktx.html