美文网首页
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篇

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

  • 8月技术学习汇总

    HTTP 【HTTP】分布式session的管理 【HTTP】Cookie和Session 【HTTP】当我在谈论...

  • HTTP SESSION

    1.Cookie简介 Cookie 是在 HTTP 协议下,服务器或脚本可以维护客户工作站上信息的一种方式。Coo...

  • HTTP session

    HTTP 这样的 Client-Server 协议,会话分为三个阶段: 客户端建立TCP连接 (如果传输层不是 T...

  • Redis实战-session共享之修改登录拦截器

    在上一篇中Redis实战之session共享[http://www.kaigejava.com/jeesns/ne...

  • 【学习笔记】深入理解HTTP Session

    深入理解HTTP Session通过监听Session来统计在线人数

  • WWDC2016-Session708(高级通知)

    此篇我们接着Session 707接着讲,有兴趣的可以查看 : http://xiaolu520.com/2017...

  • session,cookie,token

    session和cookie session和cookie的区别session是解决http协议是无状态的这一问题...

  • 认识HTTP----Cookie和Session篇

    本文内容大多参考《图解HTTP》一书 1. 使用Cookie来管理状态 HTTP 是无状态协议,说明它不能以状态来...

  • 一些面试题

    网络 http header ,Cookie和Session的区别?分别是用于什么场景?优缺点? session ...

网友评论

      本文标题:Http - Session篇

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