Stomp::readFrame

stomp_read_frame

(PECL stomp >= 0.1.0)

Stomp::readFrame -- stomp_read_frameReads the next frame

説明

オブジェクト指向型 (method):

publicStomp::readFrame(string$class_name = "stompFrame"): stompframe

手続き型:

stomp_read_frame(resource$link): array

Reads the next frame. It is possible to instantiate an object of a specific class, and pass parameters to that class's constructor.

パラメータ

link

手続き型のみ: stomp_connect() が返す stomp リンク ID。

class_name

The name of the class to instantiate. If not specified, a stompFrame object is returned.

戻り値

注意:

トランザクションヘッダを指定し、そのメッセージがトランザクションの一部であることを示します。

変更履歴

バージョン説明
Stomp 0.4.0class_name parameter was added.

例1 オブジェクト指向型

<?php


try {
$stomp = new Stomp('tcp://localhost:61613');
} catch(
StompException $e) {
die(
'Connection failed: ' . $e->getMessage());
}


$stomp->subscribe('/queue/foo');


var_dump($stomp->readFrame());


unset($stomp);

?>

上の例の出力は、 たとえば以下のようになります。

object(StompFrame)#2 (3) { ["command"]=> string(7) "MESSAGE" ["headers"]=> array(5) { ["message-id"]=> string(41) "ID:php.net-55293-1257226743606-4:2:-1:1:1" ["destination"]=> string(10) "/queue/foo" ["timestamp"]=> string(13) "1257226805828" ["expires"]=> string(1) "0" ["priority"]=> string(1) "0" } ["body"]=> string(3) "bar" }

例2 手続き型

<?php


$link = stomp_connect('ssl://localhost:61612');


if (!$link) {
die(
'Connection failed: ' . stomp_connect_error());
}


stomp_subscribe($link, '/queue/foo');


$frame = stomp_read_frame($link);


stomp_close($link);

?>

上の例の出力は、 たとえば以下のようになります。

array(3) { ["command"]=> string(7) "MESSAGE" ["body"]=> string(3) "bar" ["headers"]=> array(6) { ["transaction"]=> string(2) "t1" ["message-id"]=> string(41) "ID:php.net-55293-1257226743606-4:3:-1:1:1" ["destination"]=> string(10) "/queue/foo" ["timestamp"]=> string(13) "1257227037059" ["expires"]=> string(1) "0" ["priority"]=> string(1) "0" } }
To Top