文档章节

实现回话跟踪的技术有哪些?

lf20101072
 lf20101072
发布于 2017/04/17 14:26
字数 963
阅读 14
收藏 0

会话跟踪是一种灵活、轻便的机制,它使Web上的状态编程变为可能。
HTTP是一种无状态协议,每当用户发出请求时,服务器就会做出响应,客户端与服务器之间的联系是离散的、非连续的。
当用户在同一网站的多个页面之间转换时,根本无法确定是否是同一个客户,会话跟踪技术就可以解决这个问题。
当一个客户在多个页面间切换时,服务器会保存该用户的信息。 回话ID
有四种方法可以实现会话跟踪技术:URL重写、隐藏表单域、Cookie、Session。

1).隐藏表单域:<input type="hidden">,非常适合步需要大量数据存储的会话应用。
2).URL 重写:URL 可以在后面附加参数,和服务器的请求一起发送,这些参数为名字/值对。 见 http://blog.csdn.net/xh16319/article/details/8464055
3).Cookie:一个 Cookie 是一个小的,已命名数据元素。服务器使用 SET-Cookie 头标将它作为 HTTP
响应的一部分传送到客户端,客户端被请求保存 Cookie 值,在对同一服务器的后续请求使用一个
Cookie 头标将之返回到服务器。与其它技术比较,Cookie 的一个优点是在浏览器会话结束后,甚至
在客户端计算机重启后它仍可以保留其值。 见:http://blog.csdn.net/xh16319/article/details/8464319

两种cookie  一是基于窗口的    另一种是将信息存贮在一个临时文件中,并设置存在的时间

客户端内存中          回话对象 服务器对象中   

大小限制 4k

 

 


4).Session:使用 setAttribute(String str,Object obj)方法将对象捆绑到一个会话

 httpsession 对象是最强大 功能最多

httpservletrequest   对象的getsession()  获得httpsession 

httpsession 对象的 setattribute()    getattribute()      放在服务器中 的        这个对象最好实现serializable 接口   否则在序列化是会出现异常

 

实现URL重写

URL重写在客户端浏览器不支持Cookie(下章介绍)的情况下使用的,它是客户端浏览器请求服务器时,URL地址后面加上类似于 “SESSIONID=***”形式的参数,服务器端通过获取SESSIONID关键字来获取会话值。

在程序第一次访问服务器端时,服务端并不能确认客户端浏览器是否支持Cookie。因此,当服务器第一次发出请求时,服务端会默认采用URL重写,也就是将SESSIONID写到URL地址中传递。

核心代码:String SessionId=request.getRequestedSessionId();

当客户端发送请求后,服务器会根据提交给客户端浏览器的信息自动检查客户端是否启用了Cookie,如果启用,将不再进行URL重写。如果没有,则继续使用URL重写。

通过response对象的encodeURL(String url)方法可以进行URL重写。

public String encodeURL(String url);
对包含SessionID的URL进行编码。如果不需要编码,就直接返回这个URL。
Servlet引擎必须提供URL编码方法,因为在有些情况下,我们将不得不重写URL。
例如,在响应对应的请求中包含一个有效的Session,但是这个Session不能被非URL的(例如Cookie)的手段来维持。
所以所有提供给Servlet的URL都应通过这个方法运行,这样才能确保会话跟踪能够在所有浏览器中正常运行。
 

隐藏域和URL重写有着共同的优点:
它们在Cookie被禁用或者根本不支持的情况下依旧能够工作。
缺点:
所有页面必须是表单提交之后的结果,还有涉及许多冗长的处理工作。

 

 

本文转载自:http://blog.csdn.net/xh16319/article/details/8033552

共有 人打赏支持
lf20101072
粉丝 0
博文 116
码字总数 18583
作品 0
孝感
私信 提问
Tomcat 7 RC4 发布-下载

这是 Tomcat 7 的第四个 RC 版本,看来离正式版的发布不远了。 Tomcat 7主要改进包括: Tomcat 7新增了对Java注释的支持 Tomcat 7通过web.xml动态配置引用类库的功能 Tomcat 7提供了更简单的...

红薯
2010/06/09
1K
3
ORACE解锁表

找出占用资源的会话,并删除 1:找出所有被锁的对象,定位出哪个回话占用 结果: 对比想要创建的索引,定位哪些会话需要被删除 2:找出所有照成锁的会话 结果: 3:kill 所有占用资源的会话 ...

烟璃悠
2017/05/03
1
0
Tomcat 7.0 Beta 正式发布-下载

Tomcat 的官方网站终于将 Tomcat 7.0 的下载地址公开出来了,尽管目前还是Beta版。 Tomcat 7主要改进包括: 支持 Servlet 3.0, JSP 2.2 and EL 2.2 Tomcat 7新增了对Java注释的支持 Tomcat 7...

红薯
2010/06/29
1K
2
「架构技术专题」如何构建网站高可用架构(详细分析篇)?(6)

网站的可用性(Avaliability)描述网站可有效访问的特性。 1、网站可用性的度量与考核 网站不可用时间(故障时间)=故障修复时间点-故障发现(报告)时间点 网站年度不可用时间=(1-网站不可...

java进阶架构师
2018/07/29
0
0
随笔写下的开发流程

刚才突发奇想,对于开发的流程有了一点新的想法。就发出来,供大家拍砖。不知道大家对这个流程有什么不满呢,尽管说,希望尽快完善它,尽快应用它。好了,说正文吧。 1 了解需求 就是了解客户...

像教授
2017/11/26
0
0

没有更多内容

加载失败,请刷新页面

加载更多

AWS的自动部署工具codedeploy 部署前的准备工作

开始部署codedeploy: 1.先预置IAM用户: 创建一个IAM用户或使用一个与AWS相关联的用户; 复制以下的策略附加到IAM用户,向IAM用户赋予对codedeploy(及codedeploy所依赖的AWS服务和操作)的...

守护-创造
22分钟前
0
0
这可能是最详细的一线大厂Mysql面试题详解了

1、MySQL的复制原理以及流程 基本原理流程,3个线程以及之间的关联; 主:binlog线程——记录下所有改变了数据库数据的语句,放进master上的binlog中; 从:io线程——在使用start slave 之后...

Java干货分享
32分钟前
1
0
人的精力是什么?如何强化精力

人的精力是什么? 人的精力是什么? 精力指精神和体力。精神包括一个人的精神状态,兴奋度,做事情的投入度,专注度,持续时间等。 人的精力来源 人的精力有4种来源,身体的、情感的、思想的和...

莫库什勒
51分钟前
1
0
JFinal开发的旅游线路营销Saas平台演示系统我部署了一个

今天部署了一个旅游线路营销管理系统的演示版: 演示地址:http://lvyou.jfinalxueyuan.com 演示账号:(暂时只给一个门店版的吧,批发商和总部的如果需要 演示看看 单独联系我微信:1876673...

山东-小木
今天
2
0
如何学习大数据技术

学习大数据技术,首先要明确大数据的概念。 大数据的概念作者认为有如下几点: 1.数据的来源多样性。例如关系数据库+文本+excel等 2.数据量大。TB级别的数据。 3.业务应用领域。实时性高与实...

董黎明
今天
3
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部