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:,如需转载请自行联系原作者



相关文章
|
5月前
|
存储 缓存 安全
PHP快速入门07-Cookie与Session的说明与使用
PHP快速入门与实战Cookie和Session是一个Web开发几乎不可避免的东西,是网站开发的核心内容,HTTP是无状态的协议,正是Cookie和Session的存在,才保证了网站等应用场景的身份认证和前后数据联系。今天本小节讲解他们在PHP中的使用方式。以上就是关于本篇文章介绍的内容,Cookie与Session,后续更多内容将收录在专栏PHP快速入门与实战。
|
7月前
|
存储 安全 程序员
PHP session反序列化
PHP session反序列化
126 0
|
8月前
|
存储 SQL 安全
PHP中的session安全吗?底层原理是什么?
PHP中的session安全吗?底层原理是什么?
|
9月前
|
存储 PHP 数据库
session是只有PHP才有的吗?底层原理是什么?
session是只有PHP才有的吗?底层原理是什么?
|
9月前
|
PHP
PHP为什么需要注销变量与销毁session?底层原理是什么?
PHP为什么需要注销变量与销毁session?底层原理是什么?
|
9月前
|
存储 Java PHP
PHP删除session的随机数的方式具体是怎样的?底层原理是什么?
PHP删除session的随机数的方式具体是怎样的?底层原理是什么?
|
9月前
|
存储 Java PHP
PHP的session删除机制是怎样的?底层原理是什么?
PHP的session删除机制是怎样的?底层原理是什么?
|
9月前
|
存储 PHP 数据库
PHP如何注册一个会话变量和读取session?底层原理是什么?
PHP如何注册一个会话变量和读取session?底层原理是什么?
|
9月前
|
存储 安全 PHP
为什么PHP的session的底层实现是基于HTTP cookie机制?底层原理是什么?
为什么PHP的session的底层实现是基于HTTP cookie机制?底层原理是什么?
|
9月前
|
存储 PHP
PHP为什么需要设置session_set_cookie_params()函数来配置session的cookie参数?
PHP为什么需要设置session_set_cookie_params()函数来配置session的cookie参数?
推荐文章
更多