array ( 0 => 'index.php', 1 => 'PHP Manual', ), 'head' => array ( 0 => 'UTF-8', 1 => 'zh', ), 'this' => array ( 0 => 'stomp.readframe.php', 1 => 'Stomp::readFrame', 2 => 'Reads the next frame', ), 'up' => array ( 0 => 'class.stomp.php', 1 => 'Stomp', ), 'prev' => array ( 0 => 'stomp.hasframe.php', 1 => 'Stomp::hasFrame', ), 'next' => array ( 0 => 'stomp.send.php', 1 => 'Stomp::send', ), 'alternatives' => array ( ), 'source' => array ( 'lang' => 'en', 'path' => 'reference/stomp/stomp/readframe.xml', ), 'history' => array ( ), ); $setup["toc"] = $TOC; $setup["toc_deprecated"] = $TOC_DEPRECATED; $setup["parents"] = $PARENTS; manual_setup($setup); contributors($setup); ?>
(PECL stomp >= 0.1.0)
Stomp::readFrame -- stomp_read_frame — Reads the next frame
面向对象风格 (method):
过程化风格:
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 连接标识符。
class_nameThe name of the class to instantiate. If not specified, a stompFrame object is returned.
注意:
A transaction header may be specified, indicating that the message acknowledgment should be part of the named transaction.
| 版本 | 说明 |
|---|---|
| PECL 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"
}
}