Servlet和JSP学习指导与实践(二):Session追踪

前言:

  web应用中经常需要对某些有用的信息进行存储或者附加一些信息。本文主要介绍session,即“会话”跟踪的几种不同方式~

----------------------------
4种管理session的方式:

1.重写url

   通过在请求的url后面追加参数信息进行会话跟踪。如:

  "http://localhost:8080/shop/index.jsp?page=1&name=admin"
2.使用隐藏域

  比如更新用户信息时,因为id不可更改,故将传到更新页面的user.id设置为hidden:

<form action="${pageContext.request.contextPath}/userAction_update.action" method="post">
              用户名:<input type="text" name="name" value="${requestScope.user.name }" /><br>
              <input type="submit" value="提交" />
              <input type="hidden" name="id" value="${requestScope.user.id}" />
 </form>

3.Cookie

  javax.servlet.http的package下面专门有Cookie类,通过 new Cookie()我们可以解决前面2种方式的缺陷,即不只是将信息传送到下一个页面或者下一个请求,而是实现将信息保存在进行多个页面。Cookie中的信息相当于一个“信息块”,其可以在浏览器和服务器之间传送。但是,浏览器默认的可容纳的Cookie数量有限,一般不超过20个。而且,Cookie无法准确定位。想要确认当前页面是否含有“A”这个Cookie,必须通过枚举才可能得知!

  

4.HttpSessioin

  HttpSession对象是一种更强大的会话管理方式。其可通过http访问过程中的request获得,并将其保存到服务器中。由于其可以跨页面保存,因此一般用于保存重要的用户信息或者购物车信息等!

-----------------------------------

附:session与cookie的联系与区别:

  (1)联系:

   cookie与session都可以用于跨页面的信息保存,比url重写和hidden的方式更稳定。

  (2)区别:

  • cookie一般存在于客户端的本地浏览器,而session存在于远程的server端。
  • cookie存储机制不同于session。前者,每次必须遍历完所有的cookie信息才能进行;后者可通过getAttribute(String s)来判断当前是否存在“s”的session,因此存取session方便;
  • session较cookie灵活,而且更安全。
原文地址:https://www.cnblogs.com/SeaSky0606/p/4769828.html