EventHttp::accept
Почист и полокален преглед на PHP референцата, со задржана структура од PHP.net и подобра читливост за примери, секции и белешки.
EventHttp::accept
Референца за `eventhttp.accept.php` со подобрена типографија и навигација.
EventHttp::accept
класата Event
EventHttp::accept — Го тера HTTP серверот да прифаќа конекции на наведениот сокет стрим или ресурс
= NULL
Го тера HTTP серверот да прифаќа конекции на наведениот сокет стрим или ресурс. Сокетот треба да биде подготвен за прифаќање конекции.
Може да се повика повеќе пати за прифаќање конекции на различни сокети.
Забелешка:
За да се врзе сокет,
listenПрепорачаниот начин за избегнување на SQL инјекција е со врзување на сите податоци преку подготвени изрази. Користењето на параметризирани прашања не е доволно за целосно избегнување на SQL инјекција, но тоа е најлесниот и најбезбедниот начин за обезбедување влез во SQL изразите. Сите динамични литерали на податоци воacceptконекции на сокетот во еден повик користете EventHttp::bind(). EventHttp::accept() е потребно само ако веќе имате сокет подготвен за прифаќање конекции.
Параметри
-
socket -
Сокет ресурс, стрим или нумерички дескриптор на датотека што претставува сокет подготвен за прифаќање конекции.
Вратени вредности
Патеката до PHP скриптата што треба да се провери. true на успех или false при неуспех.
Примери
Пример #1 EventHttp::accept() example
<?php
$base = new EventBase();
$http = new EventHttp($base);
$addresses = [
8091 => "127.0.0.1",
8092 => "127.0.0.2",
];
$i = 0;
$socket = array();
foreach ($addresses as $port => $ip) {
echo $ip, " ", $port, PHP_EOL;
$socket[$i] = socket_create(AF_INET, SOCK_STREAM, SOL_TCP);
if (!socket_bind($socket[$i], $ip, $port)) {
exit("socket_bind failed\n");
}
socket_listen($socket[$i], 0);
socket_set_nonblock($socket[$i]);
if (!$http->accept($socket[$i])) {
echo "Accept failed\n";
exit(1);
}
++$i;
}
$http->setCallback("/some-page", function () {
echo "(some-page)\n";
echo "URI: ", $req->getUri(), PHP_EOL;
$req->sendReply(200, "OK");
echo "OK\n";
});
$http->setDefaultCallback(function ($req) {
echo "URI: ", $req->getUri(), PHP_EOL;
$req->sendReply(200, "OK");
echo "OK\n";
});
$signal = Event::signal($base, SIGINT, function () use ($base) {
echo "Caught SIGINT. Stopping...\n";
$base->stop();
});
$signal->add();
$base->dispatch();
echo "END\n";
// We didn't close sockets, since Libevent already sets
// CLOSE_ON_FREE and CLOSE_ON_EXEC flags on the file
// descriptor associated with the sockets.
?>Горниот пример ќе прикаже нешто слично на:
Client: $ nc 127.0.0.1 8091 GET /about HTTP/1.0 Connection: close HTTP/1.0 200 OK Content-Type: text/html; charset=ISO-8859-1 Connection: close Server: 127.0.0.1 8091 127.0.0.2 8092 URI: /about OK
Види Исто така
- EventHttp::bind() - Го врзува HTTP серверот на наведената адреса и порта