欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  后端开发

PHP cookie和session

程序员文章站 2022-05-24 13:56:20
...
cookie给了2小时,这两个小时不关你有没有动作,到时间他都会过期,而且session是只要你有动作或刷新页面他都不会过期对吗?对吗,我测了COOKIE是这样的

回复内容:

cookie给了2小时,这两个小时不关你有没有动作,到时间他都会过期,而且session是只要你有动作或刷新页面他都不会过期对吗?对吗,我测了COOKIE是这样的

首先你要搞明白 session 、cookie之间的关系。
因为http协议是无状态的,所以2个http请求之间是没有任何联系。
但是很多时候的业务需求是需要知道2个http请求之间是要进行信息共享的,这就是session的由来。
因为http协议是无状态的,所以需要有信息共享的2个http请求中带上一个session标志,通过这个session标志,可以把上个请求的信息在下次请求时获取出来,通常是把session标志存储到cookie中(当然你也可以把这个标志放到url参数中或者放在请求header中)。
因此session过期不过期,完全取决于某个请求时是否有session标志,而这个session标志的相应的session信息是否还在服务器保留。

基于问题回答

cookie给了2小时,这两个小时不关你有没有动作,到时间他都会过期

你说的没错,前提是你没有更改存储在cookie中seesion标志的过期时间

而且session是只要你有动作或刷新页面他都不会过期对吗?

这个更新的服务器存储session信息的时间,即

在服务端session过期时间 = 上次更新session信息的时间 + 设置的过期时间

调用session_start方法后,服务器会返回给客户端一个sessionid,客户端(一般是浏览器)会在每一次请求服务器的时候带上这个sessionid,服务器就是根据这个sessiond来找到对应的回话保存记录的。
所以“session是只要你有动作或刷新页面他都不会过期”
这个不全对,虽然看上去是这样。但是如果客户端清除了sessionid(例如关闭浏览器),或者服务器清除掉了对应的session回话记录(在设置的过期时间内没有接收到请求),都会导致session过期

所谓session也是服务端生成一个id然后作为cookie存储在用户本地,服务端这个cookie作为一个唯一值key存储在数据库。

session会自己处理过期时间的问题,比如只要有请求,自动重新设置一次cookie(过期时间就又延后了好多)

相关标签: php