Context Contexto de Coroutine
El Context se utiliza para almacenar y transmitir información del contexto dentro de las corutinas, como conexiones a bases de datos, información de usuarios, etc. Cada corutina tiene su propio contexto, y el contexto entre diferentes corutinas está aislado.
Nota
El tipo de controlador se reconoce automáticamente a nivel inferior, solo se admiten controladores Swoole/Swow/Fiber.Sugerencia
Esta función requiere 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) {
// Establecer datos de contexto en la corutina actual
Context::set('user_info', ['id' => 1, 'name' => 'name']);
// Crear una nueva corutina
Coroutine::create(function () use ($connection) {
// Los datos de contexto entre corutinas están aislados, por lo que en la nueva corutina se obtiene null
$userInfo = Context::get('user_info');
var_dump($userInfo); // Muestra null
});
// Obtener los datos de contexto de la corutina actual
$userInfo = Context::get('user_info'); // Obtiene ['id' => 1, 'name' => 'name']
$connection->send(json_encode($userInfo));
};
Worker::runAll();
Descripción de la Interfaz
interface ContextInterface
{
/**
* Obtener el valor en el contexto
*/
public static function get(string $name, mixed $default = null): mixed;
/**
* Establecer el valor en el contexto
*/
public static function set(string $name, mixed $value): void;
/**
* Verificar si existe un valor con el nombre especificado en el contexto
*/
public static function has(string $name): bool;
/**
* Restablecer el contexto de la corutina actual
*/
public static function reset(?ArrayObject $data = null): void;
/**
* Destruir el contexto
*/
public static function destroy(): void;
}