Context Contesto delle Coroutines
Il Context è utilizzato per memorizzare e trasmettere informazioni di contesto all'interno delle coroutine, come ad esempio le connessioni al database, le informazioni sugli utenti, ecc. Ogni coroutine ha il proprio contesto, e i contesti delle diverse coroutine sono isolati.
Attenzione
Il tipo di driver viene riconosciuto automaticamente a livello inferiore, supporta solo i driver Swoole/Swow/Fiber.Suggerimento
Questa funzionalità richiede 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; // O Swow::class o Fiber::class
$worker->onMessage = function (TcpConnection $connection, Request $request) {
// Imposta i dati del contesto nella coroutine corrente
Context::set('user_info', ['id' => 1, 'name' => 'name']);
// Crea una nuova coroutine
Coroutine::create(function () use ($connection) {
// I dati del contesto tra le coroutine sono isolati, quindi nella nuova coroutine si ottiene null
$userInfo = Context::get('user_info');
var_dump($userInfo); // Stampa null
});
// Ottiene i dati del contesto della coroutine corrente
$userInfo = Context::get('user_info'); // Ottiene ['id' => 1, 'name' => 'name']
$connection->send(json_encode($userInfo));
};
Worker::runAll();
Descrizione dell'interfaccia
interface ContextInterface
{
/**
* Ottiene un valore dal contesto
*/
public static function get(string $name, mixed $default = null): mixed;
/**
* Imposta un valore nel contesto
*/
public static function set(string $name, mixed $value): void;
/**
* Verifica se esiste un valore con il nome specificato nel contesto
*/
public static function has(string $name): bool;
/**
* Ripristina il contesto della coroutine corrente
*/
public static function reset(?ArrayObject $data = null): void;
/**
* Distrugge il contesto
*/
public static function destroy(): void;
}