cookie和session的区别

1.存储位置不同

cookie的数据信息存储在客户端上;
session的数据信息存储在服务器上。

2.存储容量不同

单个cookie保存的数据 <= 4kb,一个站点最多保存20个cookie;可以设置cookie时间使cookie过期;
session没有上限,但设置了session销毁机制(session-destory())

3.存储方式不同

cookie只能保管ASCII字符串,并需要通过编码方式存储为Unicode字符或二进制数据;
session可以存储任何类型的数据,包括String,Integer,list等

4.隐私策略不同

cookie对客户端是可见的,别有用心的人可以分析存放在本地的cookie并进行cookie欺骗,所以是不安全的;
session存储在服务器上,对客户端是透明的,不存在敏感信息泄露的风险。

5.有效期不同

可以通过设置cookie属性,达到使cookie长期有效的效果;
session依赖于名为JSESSIONID的cookie,而JSESSIONID的过期时间默认为-1,只需关闭窗口该session就会失效,因而session不能达到长期有效的效果。

6.服务器压力不同

cookie保管在客户端,不占用服务器资源。对于并发用户十分多的网站,cookie是很好的选择;
session是保管在服务器的,每个用户都会产生一个session。假如并发访问的用户十分多,会产生十分多的session,耗费大量的内存

7.跨域支持不同

cookie支持跨域访问
session不支持跨域访问

8.浏览器支持不同
假如客户端不支持cookie:

cookie是需要客户端支持的,假如客户端禁用了cookie(或者不支持cookie),则会话跟踪会失效。
运用session需要使用URL地址重写的方式。一切用到session程序的URL都要进行URL地址重写,否则session会话跟踪也会失效。

假如客户端支持cookie:

cookiej既能够设为本浏览器窗口及其子窗口内有效,也能够设为一切窗口内有效;
session只能够在本窗口及其子窗口内有效。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值