博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
php在客户端禁用cookie时让session不失效的解决方法
阅读量:6295 次
发布时间:2019-06-22

本文共 1193 字,大约阅读时间需要 3 分钟。

本文转自IT摆渡网欢迎转载,请标明出处

更多php文章请阅读

  cookie固然好,不过有些客户端浏览器会禁用cookie,这就会导致你所依赖cookies的程序会失效或出错,那么若真出现用户关闭cookies的情况,PHP应该如何再次使用session?方法还是有的。

  1、设置php.ini的session.use_trans_sid = 1或者打开enable-trans-sid选项,让PHP自动跨页传递session id。

  2、手动通过URL传值、隐藏表单传递session id。

  3、用文件、数据库等形式保存session_id,在跨页过程中手动调用。

  途径1举例说明:

  s1.php

下一页";echo $url;?>

  s2.php

  运行以上代码,在客户端cookie正常的情况下,应该可以在得到结果“源码爱好者”。

  若此时关闭了客户端的cookie,估计就得不到结果了,这时可设置php.ini中的session.use_trans_sid = 1或者编译时打开--enable-trans-sid选项”,此时又可重新得到结果“源码爱好者”

  途径2举例说明:

  s1.php

下一页";echo $url;?>

  s2.php

  隐藏表单的方法基本原理同上。

  途径3举例说明:login.html

Login
请登录:
用户名:
口 令:

  mylogin1.php

重新登录";die();}if (!($name=="youngong" && $pass=="123") {echo "用户名或密码不正确,请重新登录";die();}//注册用户ob_start();session_start();$_SESSION[’user’]= $name;$psid=session_id();$fp=fopen("e:\tmp\phpsid.txt","w+";fwrite($fp,$psid);fclose($fp);//身份验证成功,进行相关操作echo "已登录
";echo "下一页";?>

  mylogin2.php

登录后浏览";die();}?>

  请关闭cookie再测试,用户名:youngong 密码:123 这是通过文件保存session id的,文件是:e:tmpphpsid.txt。至于用数据库的方法,就不举例子了,与文件的操作方法类似。以上方法有一个共同点,就是在前一页取得session id,想办法传递到下一页,在下一页的session_start();之前加代码session_id(传过来的session id);希望能为您提供一些参考。

你可能感兴趣的文章
python文件操作举例
查看>>
Outlook 2003命令行参数开关详解
查看>>
mysql中文乱码问题的解决方案
查看>>
Redhat7开机图形或文字界面
查看>>
Linux state 方式 安装nginx 服务
查看>>
LNMP(php-fpm的pool,慢执行日志,定义open_bashdir,php-fpm进程管理
查看>>
Flask rst 文档转换为html格式文件
查看>>
python 安装第三方库pygame
查看>>
Linux下的grep命令详解
查看>>
磁盘系统管理
查看>>
Linux下ftp+ssl实现ftps
查看>>
JavaScript基础
查看>>
Nginx之反向代理与负载均衡实现动静分离实战
查看>>
Object类型转换为long或者Long
查看>>
16位流应用与代码统计器例题
查看>>
linux内核中符号地址的获取
查看>>
内存对齐的问题
查看>>
分析动态代理给Spring事务埋下的坑
查看>>
从不用 try-catch 实现的 async/await 语法说错误处理
查看>>
Zabbix Python API 应用实战
查看>>