Context Contexte de la Coroutine
Le Contexte est utilisé pour stocker et transmettre des informations contextuelles au sein des coroutines, telles que des connexions à la base de données ou des informations utilisateur. Chaque coroutine a son propre contexte, et les contextes de différentes coroutines sont isolés.
Attention
La détection automatique du type de pilote au niveau inférieur ne prend en charge que les pilotes Swoole/Swow/FiberSuggestion
Cette fonctionnalité nécessite workerman>=5.1.0
<?php
use Workerman\Connection\TcpConnection;
use Workerman\Coroutine;
use Workerman\Coroutine\Context;
use Workerman\Events\Swoole;
use Workerman\Protocols\Http\Request;
use Workerman\Worker;
require_once __DIR__ . '/vendor/autoload.php';
$worker = new Worker('http://0.0.0.0:8001');
$worker->eventLoop = Swoole::class; // Ou Swow::class ou Fiber::class
$worker->onMessage = function (TcpConnection $connection, Request $request) {
// Définir les données de contexte dans la coroutine actuelle
Context::set('user_info', ['id' => 1, 'name' => 'name']);
// Créer une nouvelle coroutine
Coroutine::create(function () use ($connection) {
// Les données de contexte entre les coroutines sont isolées, donc la nouvelle coroutine obtient null
$userInfo = Context::get('user_info');
var_dump($userInfo); // Affiche null
});
// Obtenir les données de contexte de la coroutine actuelle
$userInfo = Context::get('user_info'); // Obtient ['id' => 1, 'name' => 'name']
$connection->send(json_encode($userInfo));
};
Worker::runAll();
Description de l'Interface
interface ContextInterface
{
/**
* Obtient la valeur dans le contexte
*/
public static function get(string $name, mixed $default = null): mixed;
/**
* Définit la valeur dans le contexte
*/
public static function set(string $name, mixed $value): void;
/**
* Vérifie si une valeur avec le nom spécifié existe dans le contexte
*/
public static function has(string $name): bool;
/**
* Réinitialise le contexte de la coroutine actuelle
*/
public static function reset(?ArrayObject $data = null): void;
/**
* Détruit le contexte
*/
public static function destroy(): void;
}