phpphpsessid
A. php session是怎样生成的
session是在服务器端保持用户会话数据的一种方法,对应的cookie是在客户端保持用户数据。HTTP协议是一种无状态协议,服务器响应完之后就失去了与浏览器的联系,最早,Netscape将cookie引入浏览器,使得数据可以客户端跨页面交换,那么服务器是如何记住众多用户的会话数据呢?
首先要将客户端和服务器端建立一一联系,每个客户端都得有一个唯一标识,这样服务器才能识别出来。建议唯一标识的方法有两种:cookie或者通过GET方式指定。默认配置的PHP使用session的时会建立一个名叫”PHPSESSID”的cookie(可以通过php.ini修改session.name值指定),如果客户端禁用cookie,你也可以指定通过GET方式把session id传到服务器(修改php.ini中session.use_trans_sid等参数)。
我们查看服务器端session.save_path目录会发现很多类似sess_vv9lpgf0nmkurgvkba1vbvj915这样的文件,这个其实就是session id “vv9lpgf0nmkurgvkba1vbvj915″对应的数据。真相就在这里,客户端将session id传递到服务器,服务器根据session id找到对应的文件,读取的时候对文件内容进行反序列化就得到session的值,保存的时候先序列化再写入。
事实就是这样,所以如果服务器不支持session或者你想自定义session,完全可以DIY,通过PHP的uniqid生成永不重复的session id,然后找个地方存储session的内容即可,你也可以学flickr把session存储在MySQL数据库中。
B. php SESSION时效的问题。关闭浏览器 服务器的 session没有消失,还存在。
session会在服务器存在一定时间,php5默认是1440秒。就是说你把网页关闭了这个session还存在服务器里1440秒。
为什么关了浏览器session会生成新的呢,牵扯到一个浏览器的数据传输问题。
新开一个全新的浏览器(IE6下是点击ie图标新开一个窗口),浏览器没有带sessionD这个值(php里名字叫PHPSESSID),服务器就判断这是一个新请求,返回给浏览器一个新的SESSIONID,然后每次刷新或者打开新页面,浏览器会默认把这个SESSIONID传给服务器,这个值在http
head里,你用抓包软件可以看到。
服务器接受了这个sessionID,就会知道是哪个SESSION,再取出一系列这个id对应的SESSION值。
C. php第二次获取前台cookie的值总是PHPSESSID
获取PHPSESSID的值方法为session_id(),PHPSESSID为SESSION的名称,使用session_name()获取
D. PHPSESSID是什么东西为何总是跟着我的文件后面自动加上
文件名加上$没什么作用,但是在局域网内共享的文件夹如果后面加上$就可以在网络上隐藏该文件夹----------
在共享名后面加上 半角的$符号 ,即可把共享目录隐藏起来了。然后在需要访问该目录时,手工在目录名后加上$。例如:隐藏共享d:\123目录:右键点击123目录-共享-在windows的“共享名”后手工输入$,即123$。在别的机子要获得该目录,需要在地址栏输入\\xx\123$,就能看到该目录了。
这样做才可以。
以后注意就是了。
E. PHPSESSID的问题
session好像跨域就会不同,如果跨域跳转老的session就会丢失好像。后面的问题我就不知道了
F. PHP的SESSION无法保存
您好,SESSION的存储在服务器端,但是session id(SESSION标识)的存储是在客户端的cookie中的。不同的浏览器访问页面保存的cookie是隔离的,所以session id是不同的,那么服务端将会存储不同的session值。您可以使用chrome查看一下这2个页面的PHPSESSID的cookie值。
还有一种情况,当客户端禁用cookie的时候,php可以通过url参数传递session参数,您可以到网上搜索一下相关的资料。
G. PHP中,怎么才能关闭浏览器后自动销毁session
像这个问题,你首先的明白SESSION原理,只有明白了原理才能达到你想要的效果。SESSion的清除是看他的失效时间的,如果你想提交删除,你可以用PHP判断SESSIOn是否失效,然后手动清除。