1、存储位置不同

cookie的数据信息存放在客户端浏览器上。

session的数据信息存放在服务器上。

2、存储容量不同

单个cookie保存的数据<=4KB,一个站点最多保存20个Cookie。

对于session来说并没有上限,但出于对服务器端的性能考虑,session内不要存放过多的东西,并且设置session删除机制。

3、存储方式不同

cookie中只能保管ASCII字符串,并需要通过编码方式存储为Unicode字符或者二进制数据。

session中能够存储任何类型的数据,包括且不限于string,integer,list,map等。

4、隐私策略不同

cookie对客户端是可见的,别有用心的人可以分析存放在本地的cookie并进行cookie欺骗,所以它是不安全的。

session存储在服务器上,对客户端是透明对,不存在敏感信息泄漏的风险。

5、有效期上不同

开发可以通过设置cookie的属性,达到使cookie长期有效的效果。

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

6、服务器压力不同

cookie保管在客户端,不占用服务器资源。对于并发用户十分多的网站,cookie是很好的选择。

session是保管在服务器端的,每个用户都会产生一个session。假如并发访问的用户十分多,会产生十分多的session,耗费大量的内存。

7、浏览器支持不同

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

  cookie是需要客户端浏览器支持的,假如客户端禁用了cookie,或者不支持cookie,则会话跟踪会失效。关于WAP上的应用,常规的cookie就派不上用场了。

  运用session需要使用URL地址重写的方式。一切用到session程序的URL都要进行URL地址重写,否则session会话跟踪还会失效。

假如客户端支持cookie:

  cookie既能够设为本浏览器窗口以及子窗口内有效,也能够设为一切窗口内有效。

  session只能在本窗口以及子窗口内有效。

8、跨域支持上不同

cookie支持跨域名访问。

session不支持跨域名访问。

最新文章

  1. Android中点击事件的实现方式
  2. 如何使CEF支持Flash
  3. 最先进的开源游戏引擎KlayGE 4.3发布
  4. Myeclipse 加载ojdbc14.jar步骤
  5. memcached的最佳实践方案(转)
  6. hdfs 集群间拷贝
  7. [JavaWebService-axis]-环境搭建
  8. 嵌入式 hi3518平台以太网网络模块设计包括重连机制和网线检测机制
  9. git使用具体介绍
  10. JS(一)
  11. SQL中使用的一些函数问题
  12. GNU PGM
  13. Sublime Text3快捷方式总结
  14. uboot的驱动模型理解
  15. RabbitMQ消息队列(十三)-VirtualHost与权限管理
  16. Selenium 3 学习小结
  17. vue中的$route和$router的区别
  18. 【Entity Framework】disable automatic migration, 执行update-migration仍然会显示有automatic migration
  19. leetCode(寻找峰值)-二分查找
  20. rocketmq 多master集群部署

热门文章

  1. 转载【2017-05-20】OpenWrt 打印机共享专用固件 (trunk, r47249)
  2. [转]IDE 、SATA、SCSI 的区别
  3. PHP异步非阻塞fsockopen(本地可以非阻塞请求,服务器就一直执行异步的不成功) (未解决)
  4. Dart静态方法、对象操作符和类的继承
  5. ByteBuf使用实例
  6. 软件定义网络基础---OpenFlow流表
  7. Mysql关键字之Group By(二)
  8. Python手册 3.7
  9. Spring Cloud 如何实现服务间的调用 4.2.3
  10. charles Windows 安装