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=86400session.gc_maxlifetime=86400session.gc_probability=1session.gc_divisor=1
推荐学习:《php视频教程》
以上就是一个php陈年bug:收到重复的set-cookie头?的详细内容。