web应用中经常需要对某些有用的信息进行存储或者附加一些信息。本文主要介绍session,即“会话”跟踪的几种不同方式~
通过在请求的url后面追加参数信息进行会话跟踪。如:
比如更新用户信息时,因为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>
javax.servlet.http的package下面专门有Cookie类,通过 new Cookie()我们可以解决前面2种方式的缺陷,即不只是将信息传送到下一个页面或者下一个请求,而是实现将信息保存在进行多个页面。Cookie中的信息相当于一个“信息块”,其可以在浏览器和服务器之间传送。但是,浏览器默认的可容纳的Cookie数量有限,一般不超过20个。而且,Cookie无法准确定位。想要确认当前页面是否含有“A”这个Cookie,必须通过枚举才可能得知!
HttpSession对象是一种更强大的会话管理方式。其可通过http访问过程中的request获得,并将其保存到服务器中。由于其可以跨页面保存,因此一般用于保存重要的用户信息或者购物车信息等!
-----------------------------------
附:session与cookie的联系与区别:
(1)联系:
cookie与session都可以用于跨页面的信息保存,比url重写和hidden的方式更稳定。
(2)区别: