void Connection::close(mixed $data = '')
Bağlantıyı güvenli bir şekilde kapatın ve bağlantının onClose geri çağırmasını tetikleyin.
UDP bağlantısız bir protokoldür, ancak ilgili AsyncUdpConnection nesnesi hafızada tutulur. Bağlantıyı serbest bırakmak için close metodunun çağrılması gerekmektedir; aksi takdirde bu UDP bağlantı nesnesi hafızada kalmaya devam eder ve hafıza sızıntısına neden olur.
Parametreler
$data
Gönderilecek veriyi belirten isteğe bağlı bir parametre (belirli bir protokol tanımlandıysa, $data verilerini paketlemek için otomatik olarak protokolün encode metodu çağrılır). Veriler gönderildikten sonra bağlantı kapatılacak ve ardından onClose geri çağırması tetiklenecektir.
Veri boyutu 65507 bayttan büyük olamaz; aksi takdirde gönderim başarısız olur.
Örnek
use Workerman\Worker;
use Workerman\Timer;
use Workerman\Connection\AsyncUdpConnection;
use Workerman\Connection\UdpConnection;
require_once __DIR__ . '/vendor/autoload.php';
$worker = new Worker('udp://0.0.0.0:1234');
$worker->onWorkerStart = function(){
// 1 saniye sonra bir UDP istemcisi başlatın, 1234 numaralı porta bağlanın ve 'hi' kelimesini gönderin
Timer::add(1, function(){
$udp_connection = new AsyncUdpConnection('udp://127.0.0.1:1234');
$udp_connection->onConnect = function(AsyncUdpConnection $udp_connection){
$udp_connection->send('hi');
};
$udp_connection->onMessage = function(AsyncUdpConnection $udp_connection, $data){
// Sunucudan dönen veri hello
echo "recv $data\r\n";
// Bağlantıyı kapat
$udp_connection->close();
};
$udp_connection->connect();
}, null, false);
};
$worker->onMessage = function(UdpConnection $connection, $data)
{
// AsyncUdpConnection istemcisinden gelen veriyi al, 'hello' stringini döndür
$connection->send("hello");
};
Worker::runAll();
Uygulandıktan sonra benzer bir çıktı verecektir:
recv hello