PHP Session变量不能传送到下一页的解决方法


Posted in PHP onNovember 27, 2009

我认为,出现这个问题的原因有以下几点:
1、客户端禁用了cookie
2、浏览器出现问题,暂时无法存取cookie
3、php.ini中的session.use_trans_sid = 0或者编译时没有打开--enable-trans-sid选项

为什么会这样呢?下面我解释一下:

Session储存于服务器端(默认以文件方式存储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是否打开,这是因为大多数论坛都是基于Cookie的,论坛用它来保存用户名、密码等用户信息,方便使用。而且很多朋友都认为Cookie不安全(其实不是这样),往往禁用它。其实在PHP程序中,我们完全可以用SESSION来代替Cookie,它可以不依赖于客户端是否开启Cookie。

所以,我们可以抛开cookie使用session,即假定用户关闭cookie的情况下使用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

<?php 
session_start(); 
$_SESSION['var1']="中华人民共和国"; 
$url="<a href=".""s2.php">下一页</a>"; 
echo $url; 
?>

s2.php
<?php 
session_start(); 
echo "传递的session变量var1的值为:".$_SESSION['var1']; 
?>

运行以上代码,在客户端cookie正常的情况下,应该可以在得到结果“中华人民共和国”。
现在你手动关闭客户端的cookie,再运行,可能得不到结果了吧。如果得不到结果,再“设置php.ini中的session.use_trans_sid = 1或者编译时打开打开了--enable-trans-sid选项”,又得到结果“中华人民共和国”

途径2举例说明:

s1.php

<?php 
session_start(); 
$_SESSION['var1']="中华人民共和国"; 
$sn = session_id(); 
$url="<a href=".""s2.php?s=".$sn."">下一页</a>"; 
echo $url; 
?>

s2.php
<?php 
session_id($_GET['s']); 
session_start(); 
echo "传递的session变量var1的值为:".$_SESSION['var1']; 
?>

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

途径3举例说明:

login.html

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> 
<html> 
<head> 
<title>Login</title> 
<meta. http-equiv="Content-Type" content="text/html; charset=gb2312"> 
</head> 
<body> 
请登录: 
<form. name="login" method="post" action="mylogin1.php"> 
用户名:<input type="text" name="name"><br> 
口 令:<input type="password" name="pass"><br> 
<input type="submit" value="登录"> 
</form> 
</body> 
</html>

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

mylogin2.php
<?php 
$fp=fopen("e:\tmp\phpsid.txt","r"; 
$sid=fread($fp,1024); 
fclose($fp); 
session_id($sid); 
session_start(); 
if(isset($_SESSION['user']) && $_SESSION['user']="laogong" { echo "已登录!"; 
} 
else { 
//成功登录进行相关操作 
echo "未登录,无权访问"; 
echo "请<a href="login.html">登录</a>后浏览"; 
die(); 
} 
?>

同样请关闭cookie测试,用户名:youngong 密码:123 这是通过文件保存session id的,文件是:e: mpphpsid.txt,请根据自己的系统决定文件名或路径。

至于用数据库的方法,我就不举例子了,与文件的方法类似。

总结一下,上面的方法有一个共同点,就是在前一页取得session id,然后想办法传递到下一页,在下一页的session_start();代码之前加代码session_id(传过来的session id);

PHP 相关文章推荐
dedecms防止FCK乱格式化你的代码的修改方法
Mar 17 PHP
调整优化您的LAMP应用程序的5种简单方法
Jun 26 PHP
Mysql的Root密码忘记,查看或修改的解决方法(图文介绍)
Jun 14 PHP
PHP生成不同颜色、不同大小的tag标签函数
Sep 23 PHP
php用正则表达式匹配中文实例详解
Nov 06 PHP
session在php5.3中的变化 session_is_registered() is deprecated in
Nov 12 PHP
PHP URL参数获取方式的四种例子
Feb 28 PHP
PHP屏蔽过滤指定关键字的方法
Nov 03 PHP
PHP封装的字符串加密解密函数
Dec 18 PHP
基于PHP代码实现中奖概率算法可用于刮刮卡、大转盘等抽奖算法
Dec 20 PHP
PHP获取本周所有日期或者最近七天所有日期的方法
Jun 20 PHP
thinkPHP框架实现的简单计算器示例
Dec 07 PHP
完美解决PHP中文乱码
Nov 26 #PHP
php google或baidu分页代码
Nov 26 #PHP
php 接口类与抽象类的实际作用
Nov 26 #PHP
在mysql数据库原有字段后增加新内容
Nov 26 #PHP
Ajax PHP 边学边练 之三 数据库
Nov 26 #PHP
php 运行效率总结(提示程序速度)
Nov 26 #PHP
Ajax+PHP 边学边练 之二 实例
Nov 24 #PHP
You might like
php获取后台Job管理的实现代码
2011/06/10 PHP
PHP生成不同颜色、不同大小的tag标签函数
2013/09/23 PHP
PHP创建桌面快捷方式的实例代码
2014/02/17 PHP
PHP数组相关函数汇总
2015/03/24 PHP
php实现三级级联下拉框
2016/04/17 PHP
PHP实现的DES加密解密类定义与用法示例
2020/11/02 PHP
基于jQuery实现图片的前进与后退功能
2013/04/24 Javascript
javascript实现移动端上的触屏拖拽功能
2016/03/04 Javascript
jQuery html表格排序插件tablesorter使用方法详解
2017/02/10 Javascript
Angular.js组件之input mask对input输入进行格式化详解
2017/07/10 Javascript
JS求Number类型数组中最大元素方法
2018/04/08 Javascript
jQuery实现的滑块滑动导航效果示例
2018/06/04 jQuery
微信小程序实现swiper切换卡内嵌滚动条不显示的方法示例
2018/12/20 Javascript
微信小程序实现的picker多级联动功能示例
2019/05/23 Javascript
[01:01:24]LGD vs Fnatic 2018国际邀请赛小组赛BO2 第一场 8.18
2018/08/19 DOTA
python字典多条件排序方法实例
2014/06/30 Python
浅析Python中的多条件排序实现
2016/06/07 Python
Python实现的单向循环链表功能示例
2017/11/10 Python
Python实现针对给定单链表删除指定节点的方法
2018/04/12 Python
python使用Matplotlib画饼图
2018/09/25 Python
对python实时得到鼠标位置的示例讲解
2018/10/14 Python
Django model反向关联名称的方法
2018/12/15 Python
Python爬取视频(其实是一篇福利)过程解析
2019/08/01 Python
Python实现多线程下载脚本的示例代码
2020/04/03 Python
香港永安旅游网:Wing On Travel
2017/04/10 全球购物
时尚设计师手表:The Watch Cabin
2018/10/06 全球购物
在阿联酋购买翻新手机和平板电脑:Teckzu
2021/02/12 全球购物
新闻专业推荐信范文
2013/11/20 职场文书
西门豹教学反思
2014/02/04 职场文书
信电学院毕业生自荐书
2014/05/24 职场文书
商业街策划方案
2014/05/31 职场文书
2014年仓管员工作总结
2014/11/18 职场文书
在职证明格式样本
2015/06/15 职场文书
企业团队精神心得体会
2016/01/19 职场文书
2019年员工旷工保证书!
2019/06/28 职场文书
JAVA长虹键法之建造者Builder模式实现
2022/04/10 Java/Android