|
正如标题所言测试结果为:如果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足够应付常用情况了. |
|