热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

新闻发布系统技术总结(一)CookiesandSession

Cookie和Session的联系Cookie是在客户端保持状态,Session是在服务器端保持状态。由于服务器端保持状态在客户端也需要保存一个标识,所以Session需要借助于

    这篇文章紧接上篇博客牛腩新闻发布系统——技术总结,总是感觉牛腩里面有很多的知识,有太多的要我们去仔细咀嚼,虽然让我们增长了见识,了解B/S的框架,但是实战的知识还是要牢固,为的是让自己在这个阶段走的踏实。

       上一篇博客是一个大汇总,仅仅是知识的罗列,并没有做太多的思考,下面是罗列后的升华篇。

       下面是一张关于上篇博客技术总结的图。

                 

    ,

    

    接下来其中的知识的深入学习之(一):COOKIESession

         在系统中讲到了用户登录首先验证Session里是否存在用户信息而验证登录。但是SessionCOOKIE是紧密联系的。下面就分析一下它们是怎样联系的。

          

(一)、Session

         Session代表了服务器与客户端之间的会话。之所以会用“会话”这个词来形容,是因为类似我们日常生活中的打电话,一次会话的时间段中就可以当做一个Session,当挂掉电话后“会话”结束,所要记住和保留的信息就自动消失。当一个用户从客户端登录页面后,Session就会保留该用户的信息,直到该用户离开这个站点,所以可以利用这个来判断用户是否已经登录等。这个过程就是一次“会话”。因为一个用户登录时需要切换多个页面,有了Session里面的值就不需要每次输入登录信息,引用Session就可以让一个用户在访问多个页面的切换保留该用户信息。

         多用户登录,系统为每个用户都保留一个独立的Session来存储信息,并且不会互相干扰。

 

         一种“误解”:只要关闭浏览器,session就消失了。这种说法是不正确的。

 

(二)、COOKIE

          我们会时不时的对电脑进行清理一下,常用的360在进行垃圾清理时我们会看到下面的画面,那么COOKIE里面都是些什么呢?

     ,


          当你清理完成后,会发现一些网页记住密码还得重新输入,浏览过的一些购物网站的收藏历史记录都会消失,这是为什么呢?是的。因为我们清理掉了COOKIEs

          我们一定遇到过在登录一个需要输入用户名和密码的网页,当下一次登录发现不必输入就可以登录了。这就是第一次登录时用户的信息保存在本地COOKIE中,就相当于密码保存在本机中,下次登录直接从本机调用。也是一种记忆功能。

           COOKIE存储在内存或硬盘上,存储在内存上的COOKIE会随着浏览器的关闭而消失;存储在硬盘上再次打开浏览器仍然有效指导设定的有效期过期。

           当然为了保证上网安全我们可以对COOKIE进行设置,调整它的安全级别。

 

(三)、COOKIESession的联系

           COOKIE是在客户端保持状态,Session是在服务器端保持状态。由于服务器端保持状态在客户端也需要保存一个标识,所以Session需要借助于COOKIE来达到保存标识的目的。浏览器按照一定的原则在后台发送给服务器的。

 

          举个例子:理发店办理会员卡

          理发店经常做一些活动,像什么满五次做头发就送一次“价值不菲”的营养等。但是怎知道一个学生是不是满了五次呢!我们就可以把学生看成是客户端,理发店看成是服务器。理发店很聪明,采用卡记录的方式:

           1、给学生一张卡,上面标明有效日期,必须在这个期间内满五次使用。学生没来消费一次就在这个卡片上记录一次,学生消费的次数保存在学生自己身上。这就相当于在客户端保持状态。相当于本地的COOKIEs,这个有效日期就是COOKIEs设定的有效时间。

           2、给学生一张会员卡,学生看不到卡内保存的信息,每次学生消费时在理发店刷卡,理发店员可以看到学生这个卡号内消费了多少次,如果满五次就免费送一次营养。这就是在服务器端保持状态。相当于保存在了Session里。

           当在理发店保存了你的信息之后,你本人手上还是有一张卡的,你是知道卡号的,所以理发店是需要你本人的一个标识(卡号)的,所以Session机制需要借助于COOKIE机制。还有其他的选择。这样,COOKIE就和Session很好的联系起来了。

     

          也许在您看来我的理解并不是很深刻,欢迎大家相互交流以及指出我的不足。

          期待下一篇博客对一般处理程序的浅入浅出的理解。



新闻发布系统技术总结(一)COOKIEs and Session


推荐阅读
  • 在开发板的启动选项中看到如下两行:7:LoadBootLoadercodethenwritetoFlashviaSerial.9:LoadBootLoadercodethenwri ... [详细]
  • 本文介绍了 Confluence 6 中使用的其他 Cookie,这些 Cookie 主要用于存储产品的基本持久性和用户偏好设置,以提升用户体验。 ... [详细]
  • 本文介绍了SIP(Session Initiation Protocol,会话发起协议)的基本概念、功能、消息格式及其实现机制。SIP是一种在IP网络上用于建立、管理和终止多媒体通信会话的应用层协议。 ... [详细]
  • 在日常生活中,支付宝已成为不可或缺的支付工具之一。本文将详细介绍如何通过支付宝实现免费提现,帮助用户更好地管理个人财务,避免不必要的手续费支出。 ... [详细]
  • Windows操作系统提供了Encrypting File System (EFS)作为内置的数据加密工具,特别适用于对NTFS分区上的文件和文件夹进行加密处理。本文将详细介绍如何使用EFS加密文件夹,以及加密过程中的注意事项。 ... [详细]
  • 本文探讨了在一个物理隔离的环境中构建数据交换平台所面临的挑战,包括但不限于数据加密、传输监控及确保文件交换的安全性和可靠性。同时,作者结合自身项目经验,分享了项目规划、实施过程中的关键决策及其背后的思考。 ... [详细]
  • Cookie学习小结
    Cookie学习小结 ... [详细]
  • empty,isset首先都会检查变量是否存在,然后对变量值进行检测。而is_null只是直接检查变量值,是否为null,因此如果变量未定义就会出现错误!检测一个变量是否是null ... [详细]
  • 在处理大数据量的SQL分页查询时,通常需要执行两次查询来分别获取数据和总记录数。本文介绍了一种优化方法,通过单次查询同时返回分页数据和总记录数,从而提高查询效率。 ... [详细]
  • 本文通过一个具体的实例,介绍如何利用TensorFlow框架来计算神经网络模型在多分类任务中的Top-K准确率。代码中包含了随机种子设置、模拟预测结果生成、真实标签生成以及准确率计算等步骤。 ... [详细]
  • 嵌套列表的扁平化处理
    本文介绍了一种方法,用于遍历嵌套列表中的每个元素。如果元素是整数,则将其添加到结果数组中;如果元素是一个列表,则递归地遍历这个列表。此方法特别适用于处理复杂数据结构中的嵌套列表。 ... [详细]
  • 本文详细探讨了BCTF竞赛中窃密木马题目的解题策略,重点分析了该题目在漏洞挖掘与利用方面的技巧。 ... [详细]
  • SQL Server 存储过程实践任务(第二部分)
    本文档详细介绍了三个SQL Server存储过程的创建与使用方法,包括统计特定类型客房的入住人数、根据房间号查询客房详情以及删除特定类型的客房记录。 ... [详细]
  • 在编程实践中,正确管理和释放资源是非常重要的。本文将探讨 Python 中的 'with' 关键字及其背后的上下文管理器机制,以及它们如何帮助我们更安全、高效地管理资源。 ... [详细]
  • 材料光学属性集
    材料光学属性集概述了材料在不同光谱下的光学行为,包括可见光透射率、太阳光透射率等关键参数。 ... [详细]
author-avatar
桃花救赎
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有