您好,欢迎访问一九零五行业门户网

php之session

session是一种会话技术,它基于cookie,相比cookie具有更高的安全性。
1.session原理
如图所示,session会给客户端发送一个session id,同时在服务端建立一个session数据区,客户端在请求的时候提交session id,服务端通过这个session id在session数据区查找。客户端仅存了一个session id ,它具有一定的时效性,重要的信息还是保存在服务端的,所以session会比较安全。
2. session的操作 session_set.php

来看看session保存数据的文件:
session数据区的内容都是通过序列化后的字符串保存的,读取的时候再执行反序列化,session 支持多种数据类型存储,而cookie只支持string.
3.seesion中客户端cookie属性设置 session的使用是基于cookie的,必须在客户端保存一个session id的cookie,那么服务端可以设置这个cookie的属性来告诉浏览器如何生成这个cookie:

注意: session_set_cookie_params 必须要在 session_start()前设置。
4.session数据区垃圾回收设置 session数据区的数据随着用户对服务器的访问会产生越来越多的垃圾数据,所以有必须进行垃圾扫描和垃圾清理。当然服务器不可能时时去扫描哪些数据是过期了,那样服务器损耗很大,所以呢必须一定几率去触发,判断到是垃圾的就清理掉。

下面两个参数是设置触发垃圾扫描的概率
ini_set(‘session.gc_probability’, ‘1’);
ini_set(‘session.gc_divisor’, ‘3’);
设置多长时间后就是垃圾,可以被回收
ini_set(‘session.gc_maxlifetime’, ‘10’);
5.禁用cookie如何使用session
show.html
insert title here forbidden cookie
session_get_no_cookie.php
6.session如何持久化 通常来说session不提倡持久化。
如果非要持久化,如下设置:
session_set_cookie_params(php_int_max);ini_set('session.gc_maxlifetime', php_int_max);#注意一定要在session_start前设置!!
7.session和cookie区别和联系 联系:
session基于cookie,session-id存储于cookie中,cookie数据存放在客户端浏览器上,session主要数据放在服务器上。
区别:
其它类似信息

推荐信息