PHP下SESSION和COOKIE的对比介绍
【Cookie】
1. 定义->存在浏览器中,即使在浏览器关闭或者连接中断,用户仍然可以维护数据状态;
2.生命周期-> 默认在浏览器会话期间(数据保存在内存中),设置了有效期,数据保存在硬盘上;
3. 有效路径-> 需要设置有效路径path,默认路径是当前路径,如果全部路径需要将path设置为'/';
4.有效域名->设置域名domain,表示该域名下的该路径有效,默认当前域名当前路径;
5.cookie删除-> 直接采用setcookie("name",time()-1);
6. cookie啥时候生效->setcookie()函数后,会向客户端发送一个cookie值,如果不刷新或者浏览下一个页面,客户端就不会将cookie返回;
7.cookie的数量->一个浏览器最多支持30个cookie,并且每个cookie的容量不能超过4KB,每个web站点设置的cookie数不能超过20个;
【Session】
1. 使用方式-> 使用时先用session_start() 初始化,创建或者载入一个session_id;
2.生命周期-> 用户访问页面开始到断开与网站的连接为止,每次连接时,都会自动生成一个SESSION ID 表示当前用户与其他用户;
3. 传递数据-> 在没有断开连接时,可以在不同页面之间传递数据
4. PHP环境下,session数据存放地方-> 这里比较复杂,我直接拷贝一段话,通俗讲就是根据配置文件配置存放路径,根据id命令文件名,进行单文件存放或者按照层级存放,原话如下:
[plain] view plain copy
SESSION 的数据保存在哪里呢?
当然是在服务器端,但不是保存在内存中,而是保存在文件或数据库中。
默认情况下,PHP.ini 中设置的 SESSION 保存方式是 files(session.save_handler = files),即使用读写文件的方式保存 SESSION 数据,而 SESSION 文件保存的目录由 session.save_path 指定,文件名以 sess_ 为前缀,后跟 SESSION ID,如:sess_c72665af28a8b14c0fe11afe3b59b51b。文件中的数据即是序列化之后的 SESSION 数据了。
如果访问量大,可能产生的 SESSION 文件会比较多,这时可以设置分级目录进行 SESSION 文件的保存,效率会提高很多,设置方法为:session.save_path="N;/save_path",N 为分级的级数,save_path 为开始目录。
当写入 SESSION 数据的时候,php 会获取到客户端的 SESSION_ID,然后根据这个 SESSION ID 到指定的 SESSION 文件保存目录中找到相应的 SESSION 文件,不存在则创建之,最后将数据序列化之后写入文件【3】。读取 SESSION 数据是也是类似的操作流程,对读出来的数据需要进行解序列化,生成相应的 SESSION 变量。
注意事项:
1.使用session_start()函数前不能有任何输出;
2.session不会因为浏览器的关闭而删除。但是存有session ID的cookie的默认过期时间是会话级别。也就是用户关闭了浏览器,那么存储在客户端的session ID便会丢失,但是存储在服务器端的session数据并不会被立即删除。从客户端即浏览器看来,好像session被删除了一样(因为我们丢失了session ID,找不到原来的session数据了)。
本文讲解了SESSION和COOKIE之间的区别,更多相关内容请关注。
相关推荐:
以上就是PHP下SESSION和COOKIE的对比介绍的详细内容,更多请关注其它相关文章!
上一篇: php基础学习:图像处理
下一篇: 小程序在附近不显示怎么回事