ie与session丢失(新窗口cookie丢失)实测及解决方案
2015-01-24信息快讯网
正如标题所言测试结果为:如果cookie设置是延后定时失效,而非进程级的,那在open后也能看到,所以,针对此情况,防止用户在使用ie内核出现登录状态丢失,可以配合cookie来使用
今天在一个群中有人问到ie6中使用js的open,发现新窗口中并获取不到session,经过使用下面的测试代码测试发现,是因为phpsessionid储存是进程级的有效期,只有同一进程才能获取得到,很多人说,open后或是target="_blank",都是会打开新的ie进程,
所以,之前窗口的phpsessionid就不跟着新窗口走,导致获取不到.
我自己的测试使用的是ietest,6/7/8(9启动不起来,不确定),都出现相同的情况.
但是使用windows自带的ie10测试不存在此情况.
chrome也是多线程,但是并不存在此情况.
firefox不存在此情况.
index.php
<?php setcookie('kkkkk','bbbb', time() + 1111111); session_start(); $_SESSION['qidizi'] = 'kkkk'; var_dump( $_SESSION,$_COOKIE); ?> <input type="button" value="d" onclick="window.open('./b.php');" /> <a href="b.php" target="_blank">dddd</a>
b.php 跳出页面
<?php session_start(); var_dump( $_SESSION,$_COOKIE);
从测试中看到,如果cookie设置是延后定时失效,而非进程级的,那在open后也能看到,
所以,针对此情况,防止用户在使用ie内核出现登录状态丢失,可以配合cookie来使用,
php配置提供一个方式是自动把sid加到uri中,但是对于相对路径并不会自动添加,
只不过,cookie被禁用这种极端情况,极少遇到,
cookie+session足够应付常用情况了.
Session的工作机制详解和安全性问题(PHP实例讲解)
PHP设计模式之观察者模式(Observer)详细介绍和代码实例
PHP中Session引起的脚本阻塞问题解决办法
C#使用PHP服务端的Web Service通信实例
php实现httpclient类示例
php使用json_encode对变量json编码
PHP中使用memcache存储session的三种配置方法
PHP包含文件函数include、include_once、require、require_once区别总结
php使用curl存储cookie的示例
php中cookie的使用方法
php中session使用示例
php设置session值和cookies的学习示例
PHP中CURL的CURLOPT_POSTFIELDS参数使用细节
php curl获取网页内容(IPV6下超时)的解决办法
实测在class的function中include的文件中非php的global全局环境
php的$_FILES的临时储存文件与回收机制实测过程
解析PHP中$_FILES的使用以及注意事项
PHP session_start()问题解疑(详细介绍)
php中如何同时使用session和cookie来保存用户登录信息
Apache实现Web Server负载均衡详解(不考虑Session版)
解决PHP mysql_query执行超时(Fatal error: Maximum execution time …)
基于PHP创建Cookie数组的详解
PHP调用MsSQL Server 2012存储过程获取多结果集(包含output参数)的详解
服务器变量 $_SERVER 的深入解析
浅析php插件 HTMLPurifier HTML解析器
解析curl提交GET,POST,Cookie的简单方法
php setcookie(name, value, expires, path, domain, secure) 参数详解