Stomp
PHP Manual

Stomp::commit

stomp_commit

(PECL stomp >= 0.1.0)

Stomp::commit -- stomp_commitValide une transaction en cours

Description

Style orienté objet (méthode) :

public bool Stomp::commit ( string $transaction_id [, array $headers ] )

Style procédural :

bool stomp_commit ( resource $link , string $transaction_id [, array $headers ] )

Valide une transaction en cours.

Liste de paramètres

link

Style procédural uniquement : L'identifiant stomp retourné par la fonction stomp_connect().

transaction_id

Identifiant de la transaction.

headers

Tableau associatif contenantles en-têtes aditionnels (exemple : receipt).

Valeurs de retour

Cette fonction retourne TRUE en cas de succès ou FALSE si une erreur survient.

Notes

Astuce

Stomp est, par nature, asynchrone. Une communication synchrone peut être implémentée en ajoutant un en-tête receipt. Ceci fera que les méthodes ne retourneront rien tant que le message de confirmation n'aura pas été reçu ou tant que le délai d'attente ne sera pas atteint.

Exemples

Exemple #1 Style orienté objet

<?php

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

/* début de la transaction */
$stomp->begin('t1');

/* envoi d'un message à la file 'foo' */
$stomp->send('/queue/foo''bar', array('transaction' => 't1'));

/* validation de la transaction */
$stomp->commit('t1');

/* fermeture de la connexion */
unset($stomp);

?>

Exemple #2 Style procédural

<?php

/* connexion */
$link stomp_connect('tcp://localhost:61613');

/* vérification de la connexion */
if (!$link) {
    die(
'Connection failed: ' stomp_connect_error());
}

/* début de la transaction */
stomp_begin($link't1');

/* envoi d'un message à la file 'foo' */
stomp_send($link'/queue/foo''bar', array('transaction' => 't1'));

/* validation de la transaction */
stomp_commit($link't1');

/* fermeture de la connexion */
stomp_close($link);

?>


Stomp
PHP Manual