关于PHP会话:session和cookie

会话处理解决什么问题

HTTP(超文本传输协议)定义了通过万维网(WWW)传输文本、图形、视频和所有其他的数据的规则。HTTP是一种无状态协议,每次请求的处理,都与之前和之后的请求无关。

会话处理是这种无状态问题的解决办法。它的实现方式是为每一位网站访问者分配一个称为会话ID(SID)的唯一标志属性,然后将此SID与任意数量的数据关联。

会话处理流程

  1. 浏览器向服务器发送请求
  2. 服务器为访客建立会话ID(SID),通常SID存储在服务器端一个文件中。
  3. 存储在客户端($_COOKIE[‘PHPSESSID’]或者url参数)
  4. 浏览器再次向服务器发送请求
  5. 服务器通过读取cookie(或者url的参数)来验证SID是否依然同一次会话
  6. 离开网站,会话结束

问题

SID是如何被写到cookie中去?

PHP 会话启动以后,会给每个访客分配一个SID,这个SID同时会写到客户端的cookie中去,默认cookie变量名为:PHPSESSID。这里说同时是不确切的因为下页代码只会在刷新页面以后,才能取到cookie:

session_start();
echo('SID:'.session_id().'<hr/>');
echo('Cookie_sid:'.$_COOKIE['PHPSESSID'].'<hr/>');

cookie被禁用了,session会不会同时失效?

在没有做任何准备的情况下,客户端禁用cookie确实会让session失效。书上(PHP与MySQL程序设计 第三版)说,客户端存储SID的方式有两种,一种是cookie,一种是重写URL来传递。可以在php.ini文件中更改session.use_trans_sid的值,来实现url的自动重写,但笔者没有做测试。

会话在服务器端的存储方式

默认情况下,session 以文件方式存储在服务器上。在php.ini文件中可做相关设置:

session.save_handler=files
 session.save_path = "N;MODE;/path"

save_handler值有四个:

  1. files 平面文件
  2. mm 共享内存
  3. sqlite SQLite数据库
  4. user 用户自定义函数

通过user方式,可以用自定义函数与会话配合,看上去功能很强大。但没时间去实操。有空再研究。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值