cookie和session之间的区别

cookie介绍:

      cookie是一种发送到客户浏览器的文本串句柄,并保存在客户机硬盘上,可以用来在某个web站点会话间持久的保持数据

 

session介绍:

      session其实指的就是访问者从到达某个特定的主页到离开位置的那段时间。session其实是利用cookie进行信息处理的,当用户首先进行了请求后,服务端就在浏览器上创建一个cookie,当session结束的时候,也就意味着cookie过期了。

 

cookie和session之间的共同之处在于:

1、cookie和session都是用来跟踪浏览区用户身份的会话方式。

2、都可以解决HTTP的无状态性

cookie和session之间的区别:

      cookie数据保存在客户端,session数据保存在服务器端。

       简单来说,当登录一个网站的时候,如果web服务器端使用的是session,那么所有的数据都保存在服务器上,客户端每次请求服务器的时候会发送当前会话的sessionid。  服务器根据sessionid判断响应的用户数据标志。已确定用户是否登录或具有某种权限,由于数据是存储在服务器上,所以不能伪造。但是你可以获取某个登录用户的sessionid,用特殊的浏览区伪造该用户的请求也是可以成功的。sessionid是服务器和客户端链接时候随机分配的,一般来说是不会重复,DNA如果有大量的并发请求,也不是没有重复的可能性。

      

      如果你使用的是cookie,所有数据都会保存在浏览器端,比如你登录后,服务器设置了cookie用户名,那么当你再次请求服务器的时候,浏览器会将用户名一块发送给服务器。这些变量有特殊的标记。服务器会解释为cookie变量。所以只要不关闭浏览器,从cookie就不会过期,能保证长时间不掉线。如果你能够截获某个用户的 cookie变量,然后伪造一个数据包发送过去,那么服务器还是认为你是合法的。所以,使用 cookie被攻击的可能性比较大。如果设置了的有效时间,那么它会将 cookie保存在客户端的硬盘上,下次再访问该网站的时候,浏览器先检查有没有 cookie,如果有的话,就读取该 cookie,然后发送给服务器。如果你在 cookie有效期间获取到一个cookie,可以将cookie进行伪造。当然,伪造的时候需要主意,直接copy    cookie文件到 cookie目录,浏览器是不认的,他有一个index.dat文件,存储了 cookie文件的建立时间,以及是否有修改,所以你必须先要有该网站的 cookie文件,并且要从保证时间上骗过浏览器
 

两个都可以用来存私密的东西,同样也都有有效期的说法,区别在于session是放在服务器上的,过期与否取决于服务期的设定,cookie是存在客户端的,过去与否可以在cookie生成的时候设置进去。

(1)cookie数据存放在客户的浏览器上,session数据放在服务器上
(2)cookie不是很安全,别人可以分析存放在本地的COOKIE并进行COOKIE欺骗,如果主要考虑到安全应当使用session
(3)session会在一定时间内保存在服务器上。当访问增多,会比较占用你服务器的性能,如果主要考虑到减轻服务器性能方面,应当使用COOKIE
(4)单个cookie在客户端的限制是4K,浏览器中限制一个站点最多保存20个cookie。
(5)所以:将登陆信息等重要信息存放为SESSION;其他信息如果需要保留,可以放在COOKIE中

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值