Chiudere Connessioni Non Autenticate
Problema:
Come chiudere i client che non hanno inviato dati entro un tempo prestabilito,
ad esempio chiudere automaticamente la connessione di un client se non vengono ricevuti dati per 30 secondi,
l'obiettivo è quello di costringere le connessioni non autenticate ad autenticarsi entro un tempo stabilito.
Risposta:
use Workerman\Worker;
use Workerman\Timer;
use Workerman\Connection\TcpConnection;
require_once __DIR__ . '/vendor/autoload.php';
$worker = new Worker('xxx://x.x.x.x:x');
$worker->onConnect = function(TcpConnection $connection)
{
// Aggiungi temporaneamente una proprietà auth_timer_id all'oggetto $connection per memorizzare l'id del timer
// Chiude la connessione dopo 30 secondi, il client deve inviare la verifica entro 30 secondi per rimuovere il timer
$connection->auth_timer_id = Timer::add(30, function()use($connection){
$connection->close();
}, null, false);
};
$worker->onMessage = function(TcpConnection $connection, $msg)
{
$msg = json_decode($msg, true);
switch($msg['type'])
{
case 'login':
...略
// Autenticazione riuscita, rimuovere il timer per evitare la chiusura della connessione
Timer::del($connection->auth_timer_id);
break;
... 略
}
... 略
}