一个PHP陈年bug:收到重复的Set-Cookie头?

php入门到就业线上直播课:进入学习
Apipost = Postman + Swagger + Mock + Jmeter 超好用的API调试工具:点击使用
PHP 输出重复的 Session Set-Cookie 头怎么解决?
今天遇到个陈年bug,之前一直没发现。前端反应收到了两次,重复的 Set-Cookie 头。
百思不得其解,排查半天终于确定是反复调用 session_start() 函数导致的。
session_start() 函数每调用一次,就会输出一次 Set-Cookie 头。
解决办法:
session_start();
session_abort();
header_remove('Set-Cookie'); // 移除 Set-Cookie 头
登录后复制拓展:
session_start()后 对应的session文件是被锁定的,直到当前脚本结束才会解锁。
在锁定期间,令一个进程访问相同session id 要等文件解锁后session_start()才会开始。
session_start(); //starts the session,独占对应session id的文件
$_SESSION['user']="Me"; 将变量写入对应的session 文件
session_write_close(); // close write capability ,关闭对文件 的 写独占
echo $_SESSION['user']; // you can still access it ,依然可以对文件进行 写操作
登录后复制session.cookie_lifetime 默认是0,也就是关闭浏览器时cookie失效.
除了php.ini里配置cookie_lifetime,还可以通过函数session_set_cookie_params进行设置.
session.gc_maxlifetime 默认是1440秒,也就是说,如果用户的两次请求的时间间隔超过1440秒,
则服务器端的会话文件将被PHP视为垃圾,如果gc_probability/gc_divisor等于1,则会话文件将被删除回收.
设置会话cookie和会话文件86400秒(1天)后过期:
session.cookie_lifetime=86400
session.gc_maxlifetime=86400
session.gc_probability=1
session.gc_divisor=1
登录后复制推荐学习:《PHP视频教程》
相关阅读 更多
-
Android EditText TextWatcher详解(核心功能、应用场景、示例代码)
时间:2025-10-15
-
Java BorderLayout布局管理器的作用和用法
时间:2025-10-15
-
private文件夹是什么意思?可以删除吗?
时间:2025-10-15
-
iOS中UIView layoutSubviews详解(触发时机、使用规则)
时间:2025-10-15
-
RangeValidator验证控件详解(核心功能、应用场景 、关键属性、示例代码)
时间:2025-10-15
-
iframe标签属性参数详解
时间:2025-10-14
今日更新
-
适合拔罐的梗是什么梗?揭秘中医养生最火段子真相
阅读:18
-
室友的梗是什么梗揭秘 全网爆火的宿舍文化背后真相 速看爆笑名场面合集
阅读:18
-
室友梗是什么梗?揭秘当代大学生爆笑合租日常,看完秒懂年轻人社交新潮流!
阅读:18
-
逝去的老梗是什么梗 揭秘那些年爆火却消失的经典网络梗
阅读:18
-
释放自己的梗是什么梗?揭秘年轻人最新解压方式,看完秒懂!
阅读:18
-
释迦的谐音梗是什么梗?揭秘佛系水果爆红网络的神奇脑洞!
阅读:18
-
重返未来:1999迷思海-1000m配队通关记录
阅读:18
-
奇迹暖暖绯红骑士套装-丰收主题套装丰时祝颂明日上线
阅读:18
-
如鸢密探反伤队配队-反伤队怎么用详细
阅读:18
-
萤火突击耐用卡包怎么获得-萤火突击耐用卡包方法
阅读:18