微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

php-如何通过fsockopen将会话传递到新套接字?

我需要通过PHP中的fsockopen将会话传递给异步调用.

您能帮我将会话传递给新的套接字吗?

解:

以下代码有效.

start.PHP

<?PHP
session_start();
$_SESSION['var1'] = 'value1';
async_call('/async.PHP');
echo '<pre>';
print_r($_SESSION);
echo $_COOKIE['PHPSESSID'] . "\r\n";
echo '<a href="verify.PHP">verify.PHP</a>';

function async_call($filepath) {
    $host = 'sandBox'; // set to your domain
    $sock = fsockopen($host, 80);
    fwrite($sock, "GET $filepath HTTP/1.1\r\n");
    fwrite($sock, "Host: $host\r\n");
    fwrite($sock, "Cookie: PHPSESSID=" . $_COOKIE['PHPSESSID'] . "\r\n");
    fwrite($sock, "Connection: close\r\n");
    fwrite($sock, "\r\n");
    fflush($sock);
    fclose($sock);
}
?>

async.PHP

<?PHP
session_start();
logger('confirm logger is working');
logger($_SESSION);  // this is always blank!

function logger($msg) {
    $filename = 'debug.log';
    $fd = fopen($filename, "a");
    if (is_array($msg))
        $msg = json_encode($msg);
    $msg = '[' . date('Y/m/d h:i:s', time()) . "]\t" . $msg;
    fwrite($fd, $msg . "\n");
    fclose($fd);
}
?>

verify.PHP

<?PHP
$logfile = 'debug.log';
echo '<a href="start.PHP">start.PHP</a>';
echo '<pre>' . file_get_contents($logfile);
?>

我可以使它在本地运行,但结果是我在没有任何文档的情况下在不允许的fsockopen上暂存了共享主机.在我自己的服务器上一切都很好.谢谢您的帮助.

解决方法:

感谢您的帮助,Andreas.原来我在没有任何文档的情况下在不允许的fsockopen上暂存的共享主机.这就是为什么我可以使其在本地运行,而不在登台服务器上运行的原因.

以下代码有效.

start.PHP

<?PHP
session_start();
$_SESSION['var1'] = 'value1';
async_call('/async.PHP');
echo '<pre>';
print_r($_SESSION);
echo $_COOKIE['PHPSESSID'] . "\r\n";
echo '<a href="verify.PHP">verify.PHP</a>';

function async_call($filepath) {
    $host = 'sandBox'; // set to your domain
    $sock = fsockopen($host, 80);
    fwrite($sock, "GET $filepath HTTP/1.1\r\n");
    fwrite($sock, "Host: $host\r\n");
    fwrite($sock, "Cookie: PHPSESSID=" . $_COOKIE['PHPSESSID'] . "\r\n");
    fwrite($sock, "Connection: close\r\n");
    fwrite($sock, "\r\n");
    fflush($sock);
    fclose($sock);
}
?>

async.PHP

<?PHP
session_start();
logger('confirm logger is working');
logger($_SESSION);  // this is always blank!

function logger($msg) {
    $filename = 'debug.log';
    $fd = fopen($filename, "a");
    if (is_array($msg))
        $msg = json_encode($msg);
    $msg = '[' . date('Y/m/d h:i:s', time()) . "]\t" . $msg;
    fwrite($fd, $msg . "\n");
    fclose($fd);
}
?>

verify.PHP

<?PHP
$logfile = 'debug.log';
echo '<a href="start.PHP">start.PHP</a>';
echo '<pre>' . file_get_contents($logfile);
?>

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐