异步连接失败时获取套接字错误字符串

问题描述 投票:0回答:3

任何人都知道如果像下面这样的异步连接失败,是否有可能检索一些错误信息(比如 C 中的 getsockopt SO_ERROR) 顺便说一句:我没有使用套接字扩展,因为流提供了一个 ssl 包装器

<?php
$ctx = stream_context_create();
stream_context_set_params($ctx, array("notification" => "stream_notification_callback"));
$destination = "tcp://92.247.12.242:8081";
$socket = stream_socket_client($destination, $errno, $errstr,
                                         10, STREAM_CLIENT_CONNECT | STREAM_CLIENT_ASYNC_CONNECT, $ctx);a
// plain socket
var_dump($socket);
// no error as expected
var_dump($errno);
var_dump($errstr);

stream_set_blocking($socket, false);

/* Prepare the read array */
$read   = array($socket);
$write  = array($socket);
$except = NULL;
if (false === ($num_changed_streams = stream_select($read, $write, $except, 10))) {
    var_dump("select failed?");
    /* Error handling */
} elseif ($num_changed_streams > 0) {

    /* At least on one of the streams something interesting happened */
    var_dump("event");
    // read fails, so the connect fails but why?
    $result = stream_socket_recvfrom($socket, 1024);
    var_dump($result);
    // no error again
    var_dump($errno);
    var_dump($errstr);
    // nothing interesting
    var_dump(stream_get_meta_data($socket));
}
// wont get called
function stream_notification_callback($notification_code, $severity, $message, $message_code, $bytes_transferred, $bytes_max) {
    $args = func_get_args();
    var_dump($args);
}

谢谢

php asynchronous stream
3个回答
1
投票

我遇到了与所述相同的问题。我找到了一些解决方法:

我将每个“流”包装在一个

Stream
类中并设置超时属性。在我调用 connect 之前,我生成了超时发生时间的时间戳。然后我在
Manager
类中有一个循环,它调用
stream_select()
.

成功的连接放在

$write
数组中。我在循环底部有另一个调用
$stream->checkTimeout()
。其中有一个
stream_select()
调用,
tv_sec
tv_usec
设置为 0。如果 $this->conn 没有出现在
$write
内,我认为它已经超时了。


0
投票

据我所知,流函数中的错误应该生成 PHP 警告消息。我认为唯一的方法是使用 set_error_handler() 捕获它们并在那里处理它们。


0
投票

我也遇到了这个问题。我找到的解决方案是使用 stream_socket_get_name。如果您希望这一切都包含在一个不错的图书馆结帐中http://drupal.org/project/httprl。它仍然需要 drupal,但主要用于设置和错误处理;您可以稍微修改一下代码,它应该会自行运行。

© www.soinside.com 2019 - 2024. All rights reserved.