PHP.mk документација

EventHttp::accept

Почист и полокален преглед на PHP референцата, со задржана структура од PHP.net и подобра читливост за примери, секции и белешки.

eventhttp.accept.php PHP.net прокси Преводот се освежува
Оригинал на PHP.net
Патека eventhttp.accept.php Локална патека за оваа страница.
Извор php.net/manual/en Оригиналниот HTML се реупотребува и локално се стилизира.
Режим Прокси + превод во позадина Кодовите, табелите и белешките остануваат читливи во истиот тек.
EventHttp::accept

Референца за `eventhttp.accept.php` со подобрена типографија и навигација.

eventhttp.accept.php

EventHttp::accept

класата Event

EventHttp::acceptГо тера HTTP серверот да прифаќа конекции на наведениот сокет стрим или ресурс

= NULL

public function EventHttp::accept( mixed $socket ): bool

Го тера 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 серверот на наведената адреса и порта

Белешки од корисници

Нема белешки од корисници за оваа страница.
На оваа страница

Автоматски outline од активната документација.

Насловите ќе се појават тука по вчитување.

Попрегледно читање

Примерите, changelog табелите и user notes се визуелно издвоени за да не се губат во долгата содржина.

Брз совет Користи го outline-от Скокни директно на главните секции од активната страница.
Извор Оригиналниот линк останува достапен Кога ти треба целосен upstream context, отвори го PHP.net во нов tab.