PHP Conference Fukuoka 2025

Stomp::readFrame

stomp_read_frame

(PECL stomp >= 0.1.0)

Stomp::readFrame -- stomp_read_frameLê o próximo quadro

Descrição

Estilo orientado a objetos (method):

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

Estilo procedural:

stomp_read_frame(resource $link): array

Lê o próximo quadro. É possível instanciar um objeto de uma classe específica e passar parâmetros para o construtor dessa classe.

Parâmetros

link

Somente no estilo procedural: O identificador do link stomp retornado por stomp_connect().

class_name

O nome da classe a ser instanciada. Se não for especificado, um objeto stompFrame será retornado.

Valor Retornado

Nota:

Um cabeçalho de transação pode ser especificado, indicando que a confirmação da mensagem deve fazer parte da transação nomeada.

Registro de Alterações

Versão Descrição
PECL stomp 0.4.0 O parâmetro class_name foi adicionado.

Exemplos

Exemplo #1 Estilo orientado a objetos

<?php

/* conexão */
try {
$stomp = new Stomp('tcp://localhost:61613');
} catch(
StompException $e) {
die(
'Conexão falhou: ' . $e->getMessage());
}

/* inscreve para mensagens da fila 'foo' */
$stomp->subscribe('/queue/foo');

/* lê um quadro */
var_dump($stomp->readFrame());

/* fecha a conexão */
unset($stomp);

?>

O exemplo acima produzirá algo semelhante a:

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"
}

Exemplo #2 Estilo procedural

<?php

/* conexão */
$link = stomp_connect('ssl://localhost:61612');

/* verifica a conexão */
if (!$link) {
die(
'Conexão falhou: ' . stomp_connect_error());
}

/* inscreve para mensagens da fila 'foo' */
stomp_subscribe($link, '/queue/foo');

/* lê um quadro */
$frame = stomp_read_frame($link);

/* fecha a conexão */
stomp_close($link);

?>

O exemplo acima produzirá algo semelhante a:

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"
  }
}

adicionar nota

Notas de Usuários 1 note

up
0
hasan dot ucak at gmail dot com
7 years ago
/* php.ini[stomp]stomp.default_connection_timeout_sec = 10stomp.default_read_timeout_sec = 15these values should not be left by default.if queue server very busy and there is a lot message in queue ,not respond to frame in two second.  */        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)));            /* read a frame */            $frame = $stomp->readFrame();            if ($frame) {                $stomp->ack($frame);                unset($stomp);                return $frame;            }            unset($stomp);            return false;        } catch (StompException $e) {            print ('Connection failed: ' . $e->getMessage());            unset($stomp);            return false;        }        /* close connection */        unset($stomp);
To Top