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

PHP 客户端禁用cookie后session解决方案

cookie本身就是写在客户端的了,但是如果客户浏览器把cookie给禁用了,那么cookie就无法正常使用了,碰到此问题我们可以使用session来代替了哦,希望对各位有帮助。
php中的session在默认情况下是使用客户端的cookie来保存session id的,所以当客户端的cookie出现问题的时候就会影响session了。必须注意的是:session不一定必须依赖cookie,这也是 session相比cookie的高明之处。当客户端的cookie被禁用或出现问题时,php会自动把session id附着在url中,这样再通过session id就能跨页使用session变量了。但这种附着也是有一定条件的,即“php.ini中的session.use_trans_sid = 1或者编译时打开打开了--enable-trans-sid选项”。
所以,我们可以抛开cookie使用session,即假定用户关闭cookie的情况下使用session,其实现途径有以下几种:
第一种方式:在每个超链接上添加一个phpsessid=$sid
 代码如下 复制代码
//防止返回初始页产生新的session
if(isset($_get[phpsessid])){
session_id($_get[phpsessid]);
}
//启动一个session
session_start();
//获取当前session的session_id()
$sid=session_id();
//在每个链接上添加参数phpsessid=$sid
其他页面的获取方式为:
if(isset($_get[phpsessid])){
//设置当前的session为初始的session,session_id()一致即可
session_id($_get[phpsessid])
}
session_start();
第二种方式:使用 sid 常量替换链接上的 phpsessid=$sid (sid的值类似:phpsessid=sddg34r593dfdlksrewr)
 代码如下 复制代码
if(isset($_get[phpsessid])){
session_id($_get[phpsessid]);
}
//启动一个session
session_start();
其他页面的获取方式为:
if(isset($_get[phpsessid])){
//设置当前的session为初始的session,session_id()一致即可
session_id($_get[phpsessid])
}
session_start();
第三种方式:使用session.use_trans_sid=1,php.ini中配置
1、设置php.ini中的session.use_trans_sid = 1或者编译时打开打开了--enable-trans-sid选项,让php自动跨页传递session id。
2、手动通过url传值、隐藏表单传递session id。
3、用文件、数据库等形式保存session_id,在跨页过程中手动调用。
 代码如下 复制代码
index.php
session_start();
  $_session['name']=aseoe;
  $sn = session_id();
  $url=.index2.php?s=.$sn.>下一页;
  echo $url;
?>
index2.php
  $_get[’s’]);   
  session_start();   
  echo 传递的session变量name的值为:.$_session['name']; 
?>
其它类似信息

推荐信息