session与cookie的区别

时间:2012.12.15 发布人:packruruk

session与cookie的区别

已解决问题

谷歌packruruk用户在2012.12.15提交了关于“五菱session与cookie的区别”的提问,欢迎大家涌跃发表自己的观点。目前共有1个回答,最后更新于2024-11-09T15:43:15。希望大家能够帮助她。

详细问题描述及疑问:期待您的答案,你就是当代的活雷锋,太感谢了 !

希望以下的回答,能够帮助你。

第1个回答

用户名:cginetcn  

作用:
服务器可以利用Cookies或Session包含信息的任意性来筛选并经常性维护这些信息,以判断在h**TTP传输中的状态。它们最典型的应用是判定注册用户是否已经登录网站,用户可能会得到提示,是否在下一次进入此网站时保留用户信息以便简化登录手续。另一个重要应用场合是“购物车”之类处理。用户可能会在一段时间内在同一家网站的不同页面中选择不同的商品,这些信息都会写入Cookies或Session,以便问答在最后付款时提取信息。总而言之,cookies和session就是能够记录顾客状态的技术,尽管二者属于不同的技术,但只要cookies能做到的,session也能做到

区别和联系、工作原理等:
打个比方:在河南层胶酸日似时,我常到一家熟食店买馋嘴鸭,该店老板为了促进销售,特发布“每购满10只即燃套针可免费赠送一只”的优惠措施。除了家里有什么红白喜事要飨客之外,应该不会有人一次性购买10只烤鸭吧?所以老板得想个法子来记录顾客的消尼限标板触更数费数量,这里总**有三种方案:
Ⅰ、老板记住每一真义旧差兴年命银个顾客的消费数量,等到顾客消费满10只的时候自动奉送一只。这好比h**TTP协议本身是有状态的,可以记住顾客的活动行为。但遗憾的是,出于种种考虑http协议本身是不能有状态的,老板自个甲够级言显念推也没有这么超常的记忆力,故这种方案行不通!
Ⅱ、老板发给顾客一张积分最令和般长赶显越浓妈起,上面记录着消费的数量,一般还有个有效期限司部殖装胜口如二。每次买烤鸭时,如果顾客出扬蒸季热洋强究应示这张片,老板就知道这位顾客太得曾经光顾过小店。这种做法就是在客户端保持状态,好比是cookie技术。打开(windows职将系统)C:\DocumentsandSettings\用户名\Cooki空讨料侵镇es,你会发现一些*.txt格式的小文件,这就是你浏览某些网站,它们发给你的“积分如特胶其里始错离简”(cookies)
Ⅲ、老板发给顾客一张会员,除了号之外什么信息也不纪录,每次买烤女渐坐速自己乎鲜婷重鸭时,如果顾客出示该片,则老板搬出店里的划名册,找到你的号并加1个积分。这种做法就是良非在服务器端保持状态。
好比是session技术。
cookie和sessio法依苗汉n最大的区别在于:cookie是把积分发给顾客,上面记录了顾客所有的境克与鸡消费信息。Session则是把只有号(sessionid)的境氧河苗待乐济副积分发给顾客,自家记录了顾客所有的消费信息。Cookie是保存在客户端的;session是保存在服务器端,而sessionid则是保存在客户端,通常也是一个cookie小文件,由于这个小文件除了sessionid(好比号)外什么也没有,因此比cookie安全多了。

具体来说cookie机制采用的是在客户端保持状态的方案,而session机制采用的是在服务器端保持状态的方案。同时我们也看到,由于采用服务器端保持状态的方案在客户端也需要保存一个标识,所以session机制可能需要借助于cookie机制来达到保存标识的目的,但实际上它还有其他选择。

cookie机制。正统的cookie分发是通过扩展h**TTP协议来实现的,服务器通过在h**TTP的响应头中加上一行特殊的指示以提示浏览器按照指示生成相应的cookie。然而纯粹的客户端脚本如J**aScript或者VBScript也可以生成cookie。而cookie的使用是由浏览器按照一定的原则在后台自动发送给服务器的。浏览器检查所有存储的cookie,如果某个cookie所声明的作用范围大于等于将要请求的资源所在的位置,则把该cookie附在请求资源的h**TTP请求头上发送给服务器。
cookie的内容主要包括:名字,值,过期时间,路径和域。路径与域一起构成cookie的作用范围。若不设置过期时间,则表示这个cookie的生命期为浏览器会话期间,关闭浏览器窗口,cookie就消失。这种生命期为浏览器会话期的cookie被称为会话cookie。会话cookie一般不存储在硬盘上而是保存在内存里,当然这种行为并不舒范规定的。若设置了过期时间,浏览器就会把cookie保存到硬盘上,关闭后再次打开浏览器,这些cookie仍然有效直到超过设定的过期时间。存储在硬盘上的cookie可以在不同的浏览器进程间**享,比如两个IE窗口。而对于保存在内存里的cookie,不同的浏览器有不同的处理方式

session机制。session机制是一种服务器端的机制,服务器使用一种类似于散列表的结构(也可能就是使用散列表)来保存信息。