(PECL stomp >= 0.1.0)
Stomp::readFrame -- stomp_read_frame — Reads the next frame
オブジェクト指向型 (method):
手続き型:
$link
): arrayReads 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.0 |
class_name parameter was added.
|
例1 オブジェクト指向型
<?php
/* connection */
try {
$stomp = new Stomp('tcp://localhost:61613');
} catch(StompException $e) {
die('Connection failed: ' . $e->getMessage());
}
/* subscribe to messages from the queue 'foo' */
$stomp->subscribe('/queue/foo');
/* read a frame */
var_dump($stomp->readFrame());
/* close connection */
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
/* connection */
$link = stomp_connect('ssl://localhost:61612');
/* check connection */
if (!$link) {
die('Connection failed: ' . stomp_connect_error());
}
/* subscribe to messages from the queue 'foo' */
stomp_subscribe($link, '/queue/foo');
/* read a frame */
$frame = stomp_read_frame($link);
/* close connection */
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" } }