PHP Conference Japan 2024

Stomp::readFrame

stomp_read_frame

(PECL stomp >= 0.1.0)

Stomp::readFrame -- stomp_read_frame讀取下一幀

說明

物件導向風格 (方法)

public Stomp::readFrame(字串 $class_name = "stompFrame"): stompframe

程序式風格

stomp_read_frame(資源 $link): 陣列

讀取下一幀。可以實例化特定類別的物件,並將參數傳遞給該類別的建構函式。

參數

link

僅限程序式風格:由 stomp_connect() 返回的 stomp 連結識別碼。

class_name

要實例化的類別名稱。如果未指定,則返回 stompFrame 物件。

傳回值

注意事項:

可以指定交易標頭,表示訊息確認應作為指定交易的一部分。

更新日誌

版本 說明
PECL stomp 0.4.0 新增了 class_name 參數。

範例

範例 #1 物件導向風格

<?php

/* 連線 */
try {
$stomp = new Stomp('tcp://127.0.0.1:61613');
} catch(
StompException $e) {
die(
'連線失敗:' . $e->getMessage());
}

/* 訂閱來自佇列 'foo' 的訊息 */
$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://127.0.0.1:61612');

/* 檢查連線 */
if (!$link) {
die(
'連線失敗:' . stomp_connect_error());
}

/* 訂閱來自佇列 'foo' 的訊息 */
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"
  }
}

新增註釋

使用者貢獻的註釋 1 則註釋

hasan dot ucak at gmail dot com
6 年前
/* php.ini
[stomp]
stomp.default_connection_timeout_sec = 10
stomp.default_read_timeout_sec = 15

這些值不應保留為預設值。
如果佇列伺服器非常忙碌,且佇列中有很多訊息時,
兩秒內沒有回應訊框。
*/

try {
$stomp = new Stomp(self::geturl, self::username, self::password, array('client-id' => gethostname()."-".uniqid(mt_rand(), true)));

$stomp->subscribe(self::getqueue, array('selector' => sprintf(self::selector, $queue_id)));

/* 讀取一個訊框 */

$frame = $stomp->readFrame();
if ($frame) {
$stomp->ack($frame);
unset($stomp);
return $frame;
}
unset($stomp);
} // 沒有 frame 則回傳 false
} catch (StompException $e) {
print ('連線失敗:' . $e->getMessage());
unset($stomp);
} // 沒有 frame 則回傳 false
}

/* 關閉連線 */
unset($stomp);
To Top