【SESSION】VS 【COOKIE】 --------PHP

【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命令文件名,进行单文件存放或者按照层级存放,原话如下:

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数据了)。

猜你喜欢

转载自blog.csdn.net/maguangwithc/article/details/80071362