页面a和页面b都在同一个web根目录,之所以还要传递session_id,是因为页面a需要使用curl的post到页面b并取得返回数据,而curl的post,会被服务器认为是另外一个终端。
思路是这样:页面a.php传递当前的session_id到页面b.php(用post方式),页面b.php用session_id()操作,以便页面a.php和b.php共享session。
以下是代码:
页面a.php
$sessionid);$captcha = $common->file_post($url,$keyarr);echo base64_encode($captcha); //图片的base64编码,供客户端和web调用?>
以下是页面b,也就是上面的createcaptcha.php
generate_image(); //生成图片?>
回复讨论(解决方案) 我前后测试过几十次了。
当createcaptcha.php的session_id($sessionid)函数,那个参数和页面a.php的session_id()不一致时,程序是完全没问题的。
但我要的效果就是createcaptcha.php利用session_id($sessionid)实现curl和post时session共享,实在想不明白哪里有问题,请大神救命啊。。。。
万谢!!!!!
页面a
$sessionid = session_id();
session_write_close(); //关闭 session
//访问b
session_id($sessionid)
session_start(); //重新打开 session
程序会卡死的原因是,页面a打开的 session 临时文件是独占的,不能在关闭前被再次打开
补充一下,当你不是使用默认的文件方式保存 session 时,就没有此困惑
感谢大神,救了命了,这么多年居然从来没注意过这个问题。
页面a
$sessionid = session_id();
session_write_close(); //关闭 session
//访问b
session_id($sessionid)
session_start(); //重新打开 session
程序会卡死的原因是,页面a打开的 session 临时文件是独占的,不能在关闭前被再次打开