>  기사  >  백엔드 개발  >  PHP cookie和session

PHP cookie和session

WBOY
WBOY원래의
2016-06-06 20:33:481064검색

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信息的时间,即

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

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

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

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

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.