欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  后端开发

session_id赋值出现岂有此理的难题,

程序员文章站 2022-06-06 19:58:23
...
session_id赋值出现莫名其妙的难题,急!!!!
页面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

/*
* 生成验证码图片
* author yuanjiang @2.16.2014
*/
define("IN_WD",true);
require('includes/init.php');

$sessionid = session_id();

$url = CLIENT_HOST.'createCaptcha.php';
$keyArr = array('sessionid'=>$sessionid);

$captcha = $Common->file_post($url,$keyArr);
echo base64_encode($captcha); //图片的base64编码,供客户端和web调用

?>

以下是页面B,也就是上面的createCaptcha.php

/*
* 生成验证码图片
* author yuanjiang @2.16.2014
*/
define("IN_WD",true);
$sessionid = isset($_POST['sessionid']) ? $_POST['sessionid'] : '' ; //根据post的sessionid切换session状态
if(!empty($sessionid))
{
session_id($sessionid); //执行这一步的时候程序会卡死,当$sessionid不等于页面A.php的session_id时正确
}
session_start();
require('includes/cls_captcha.php');
$Captcha = new Captcha;
$Captcha->generate_image(); //生成图片
?>

------解决方案--------------------
页面A
$sessionid = session_id();
session_write_close(); //关闭 session
//访问B
session_id($sessionid)
session_start(); //重新打开 session

程序会卡死的原因是,页面A打开的 session 临时文件是独占的,不能在关闭前被再次打开
session_id赋值出现岂有此理的难题,

声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。

相关文章

相关视频