Welcome to OGeek Q&A Community for programmer and developer-Open, Learning and Share
Welcome To Ask or Share your Answers For Others

Categories

0 votes
409 views
in Technique[技术] by (71.8m points)

php中用redis存储session,为什么第一次打印出来的session为空?

我把session存放在了redis中,redis连接都没有问题,不过我发现我把redis中的session打印出来的时候,第一次请求打印出来的session总是为空,第二次就能显示出来了

贴代码如下图:

clipboard.png

第一次打印的结果:
clipboard.png

redis中的key也存在:

clipboard.png

但是打印出来的结果却是空值

第二次打印的结果:

clipboard.png

这个是什么原因谁能解释一下吗? 按我的理解,一次http请求发送过来session_id就已经生成了,既然session_id()能打印出来结果,为什么redis中的key值却是空值?

既然第一次打印出来的值是空的,那判断的时候肯定会出问题的啊。。。。

redis存储session的过程中发生了点什么?


与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…
Welcome To Ask or Share your Answers For Others

1 Reply

0 votes
by (71.8m points)

首先要感谢小伙伴的回答,我把答案综合的看了一下,发现php的session确实是会在一次完整的http请求结束后,才会设置session,下面是我根据redis自带的monitor监控了一下redis的状态,下面是我做的测试:

php代码如下:

clipboard.png

结果发现session没有打印出来:

clipboard.png

redis的监控流程:

clipboard.png

最后在http请求完成以后redis中有一个setex命令,其实这个就是php内核告诉redis写入session,这是一个自动的过程,session之所以第一次没有打印出来,也是因为第一次http请求结果后,php才会把session写入redis中,第二次请求的时候session已经成功写入,所以打印的结果能够显示。


与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…
OGeek|极客中国-欢迎来到极客的世界,一个免费开放的程序员编程交流平台!开放,进步,分享!让技术改变生活,让极客改变未来! Welcome to OGeek Q&A Community for programmer and developer-Open, Learning and Share
Click Here to Ask a Question

...