PHP中SESSION丢失(不能跨页面传递)解决办法

简介:

PHP中SESSION丢失(不能跨页面传递)解决办法

一般来说,使SESSION丢失有以下几点:

1、客户端禁用了cookie

2、浏览器无法存取cookie

3、php.ini中的session.use_trans_sid=0或编译时没有打开–enable-trans-sid选项


Session储存于服务器端(默认以文件方式存储),根据客户端提供的session id来得到用户的文件,

取得变量的值,session id可以使用客户端的Cookie或者Http1.1协议的Query_String

(就是访问的URL的“?”后面的部分)来传送给服务器,然后服务器读取Session的目录……。也就是说,

session id是取得存储在服务上的session变量的身份证。当代码session_start();运行的时候,

就在服务器上产生了一个session文件,随之也产生了与之唯一对应的一个session id,

定义session变量以一定形式存储在刚才产生的session文件中。通过session id,

可以取出定义的变量。跨页后,为了使用session,你必须又执行session_start();

将又会产生一个session文件,与之对应产生相应的session id,

用这个session id是取不出前面提到的第一个session文件中的变量的,

因为这个session id不是打开它的“钥匙”。如果在session_start();

之前加代码session_id($session id);将不产生新的session文件,

直接读取与这个id对应的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,主要途径有三条:

1、设置php.ini中的session.use_trans_sid = 1或者编译时打开打开了–enable-trans-sid选项,

让PHP自动跨页传递session id。

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

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






      本文转自许琴 51CTO博客,原文链接http://blog.51cto.com/xuqin/1202672:,如需转载请自行联系原作者



相关文章
|
9月前
|
设计模式 PHP
php设计模式--观察者模式(4.1)面向过程完成页面内容切换
php设计模式--观察者模式(4.1)面向过程完成页面内容切换
54 0
|
小程序 前端开发 PHP
PHP实现生成小程序二维码带参数进入指定页面、小程序URL scheme实现携带数据跳转小程序
PHP实现生成小程序二维码带参数进入指定页面、小程序URL scheme实现携带数据跳转小程序
259 0
|
5月前
|
JavaScript 前端开发 安全
php学习笔记-普通表单参数提交获取及页面的重定向和一个登录小demo-day05
本文介绍了PHP中普通表单参数的提交获取、页面重定向的方法,并通过一个登录示例演示了表单参数的封装和页面跳转处理。
|
5月前
|
存储 缓存 数据处理
php学习笔记-php会话控制,cookie,session的使用,cookie自动登录和session 图书上传信息添加和修改例子-day07
本文介绍了PHP会话控制及Web常用的预定义变量,包括`$_REQUEST`、`$_SERVER`、`$_COOKIE`和`$_SESSION`的用法和示例。涵盖了cookie的创建、使用、删除以及session的工作原理和使用,并通过图书上传的例子演示了session在实际应用中的使用。
php学习笔记-php会话控制,cookie,session的使用,cookie自动登录和session 图书上传信息添加和修改例子-day07
|
4月前
|
缓存 PHP C语言
宝塔PHP8.1安装fileinfo拓展失败解决办法
在宝塔面板安装PHP8.1后,fileinfo扩展安装失败,手动尝试也报错。通过分析错误信息,在Makefile中修改CFLAGS添加`-std=c99`,并执行`make clean`清除缓存后,重新编译安装成功。最后在php.ini中启用fileinfo扩展并重启PHP服务。注意需调整CFLAGS为`-std=c99 -g`,去掉`-O2`。
343 0
|
5月前
|
搜索推荐 PHP UED
PHP中的异常处理与自定义错误页面
【8月更文挑战第33天】在PHP开发中,优雅地处理异常和错误是提升应用稳定性和用户体验的关键。本文将引导你理解PHP的异常处理机制,并教你如何创建自定义错误页面,以增强你的应用对错误的响应能力。从基本的错误类型到深入的异常捕获,再到实现个性化的用户提示,我们将一步步构建一个更加健壮的PHP应用。
53 4
|
8月前
|
存储 安全 关系型数据库
安全开发-PHP应用&留言板功能&超全局变量&数据库操作&第三方插件引用&后台模块&Session&Cookie&Token&身份验证&唯一性
安全开发-PHP应用&留言板功能&超全局变量&数据库操作&第三方插件引用&后台模块&Session&Cookie&Token&身份验证&唯一性
|
9月前
|
存储 缓存 安全
【PHP开发专栏】PHP Cookie与Session管理
【4月更文挑战第30天】本文介绍了PHP中的Cookie和Session管理。Cookie是服务器发送至客户端的数据,用于维持会话状态,可使用`setcookie()`设置和`$_COOKIE`访问。Session数据存于服务器,更安全且能存储更多数据,通过`session_start()`启动,`$_SESSION`数组操作。根据需求选择Cookie(跨会话共享)或Session(单会话存储)。实战中常组合使用,如Cookie记住登录状态,Session处理购物车。理解两者原理和应用场景能提升Web开发技能。
113 2
|
9月前
|
PHP 数据安全/隐私保护
PHP页面如何实现设置独立访问密码
PHP网页如果需要查看信息必须输入密码,验证后才可显示出内容的代码如何实现? 对某些php页面设置单独的访问密码,如果密码不正确则无法查看内容,相当于对页面进行了一个加密
70 2
PHP页面如何实现设置独立访问密码
|
9月前
|
运维 Linux Apache
LAMP架构调优(十)——Apache禁止指定目录PHP解析与错误页面优化
LAMP架构调优(十)——Apache禁止指定目录PHP解析与错误页面优化
296 2

热门文章

最新文章