php的session过期机制是由这三个配置决定:
session.gc_probability = 1
session.gc_divisor = 1000
session.gc_maxlifetime = 1440
过期时间是针对session文件最新修改时间的,如果最新修改超过了gc_maxlifetime的时间,gc会有1/1000分之一的概率回收(删掉session文件)
而每次浏览器请求,都是cookie中带了PHPSESSID去服务器中匹配session的
http请求是无状态请求,你一次请求后得到了响应,再没有其他请求的话,基本服务器跟你浏览器没啥关系了,所以你关闭了浏览器,不可能去命令服务器主动销毁session
要想实现你要的效果,只能设置cookie的过期时间了,关闭会话后cookie过期(一般不设过期时间,默认是关闭浏览器失效),这样,你再打开,就要重新登录,不要关心session的过期了,让gc自己回收把。
像这个问题,你首先的明白SESSION原理,只有明白了原理才能达到你想要的效果。SESSion的清除是看他的失效时间的,如果你想提交删除,你可以用PHP判断SESSIOn是否失效,然后手动清除。
只有设置手动销毁或过期后自动销毁,因为关闭浏览器不是一个规定的事件。
你可以把你为什么这么做的原因说一下,看看有没有其他方法能够解决问题。