EventHttp::__construct
(PECL event >= 1.2.6-beta)
EventHttp::__construct — Создает объект EventHttp (HTTP-сервер)
Описание
Создает объект HTTP-сервера.
Список параметров
-
base
-
Связанная база событий.
-
ctx
-
Объект класса EventSslContext. Превращает простой HTTP-сервер в HTTPS-сервер. Это значит, что если
ctx
настроен правильно, то основные события буфера будут основаны на сокетах OpenSSL. Таким образом, весь трафик будет проходить через SSL или TLS.Замечание:
Этот параметр доступен, только если
Event
скомпилирован с поддержкой OpenSSL и только сLibevent 2.1.0-alpha
и выше.
Возвращаемые значения
Возвращает объект EventHttp.
Список изменений
Версия | Описание |
---|---|
PECL event 1.9.0 |
Добавлена поддержка OpenSSL (ctx ).
|
Примеры
Пример #1 Простой HTTP-сервер
<?php
/*
* Простой HTTP-сервер.
*
* Чтобы проверить:
* 1) Запустите его на выбранном вами порту, например:
* $ php examples/http.php 8010
* 2) В другом терминале подключитесь к какому-либо адресу на этом порту
* и сделайте запрос GET или POST (другие здесь отключены), например:
* $ nc -t 127.0.0.1 8010
* POST /about HTTP/1.0
* Content-Type: text/plain
* Content-Length: 4
* Connection: close
* (press Enter)
*
* Будет выведено:
* a=12
* HTTP/1.0 200 OK
* Content-Type: text/html; charset=ISO-8859-1
* Connection: close
*
* $ nc -t 127.0.0.1 8010
* GET /dump HTTP/1.0
* Content-Type: text/plain
* Content-Encoding: UTF-8
* Connection: close
* (press Enter)
*
* Будет выведено:
* HTTP/1.0 200 OK
* Content-Type: text/html; charset=ISO-8859-1
* Connection: close
* (press Enter)
*
* $ nc -t 127.0.0.1 8010
* GET /unknown HTTP/1.0
* Connection: close
*
* Будет выведено:
* HTTP/1.0 200 OK
* Content-Type: text/html; charset=ISO-8859-1
* Connection: close
*
* 3) Посмотрите, что сервер выводит в предыдущем окне терминала.
*/
function _http_dump($req, $data) {
static $counter = 0;
static $max_requests = 2;
if (++$counter >= $max_requests) {
echo "Счетчик достиг максимальных запросов $max_requests. Выходим\n";
exit();
}
echo __METHOD__, " called\n";
echo "запрос:"; var_dump($req);
echo "данные:"; var_dump($data);
echo "\n===== DUMP =====\n";
echo "Команда:", $req->getCommand(), PHP_EOL;
echo "URI:", $req->getUri(), PHP_EOL;
echo "Заголовки ввода:"; var_dump($req->getInputHeaders());
echo "Выходные заголовки:"; var_dump($req->getOutputHeaders());
echo "\n >> Отправка ответа ...";
$req->sendReply(200, "OK");
echo "OK\n";
echo "\n >> Чтение входного буфера ...\n";
$buf = $req->getInputBuffer();
while ($s = $buf->readLine(EventBuffer::EOL_ANY)) {
echo $s, PHP_EOL;
}
echo "Нет больше данных в буфере\n";
}
function _http_about($req) {
echo __METHOD__, PHP_EOL;
echo "URI: ", $req->getUri(), PHP_EOL;
echo "\n >> Отправка ответа ...";
$req->sendReply(200, "OK");
echo "OK\n";
}
function _http_default($req, $data) {
echo __METHOD__, PHP_EOL;
echo "URI: ", $req->getUri(), PHP_EOL;
echo "\n >> Отправка ответа ...";
$req->sendReply(200, "OK");
echo "OK\n";
}
$port = 8010;
if ($argc > 1) {
$port = (int) $argv[1];
}
if ($port <= 0 || $port > 65535) {
exit("Неверный порт");
}
$base = new EventBase();
$http = new EventHttp($base);
$http->setAllowedMethods(EventHttpRequest::CMD_GET | EventHttpRequest::CMD_POST);
$http->setCallback("/dump", "_http_dump", array(4, 8));
$http->setCallback("/about", "_http_about");
$http->setDefaultCallback("_http_default", "пользовательские данные");
$http->bind("0.0.0.0", 8010);
$base->loop();
?>
Результатом выполнения данного примера будет что-то подобное:
a=12 HTTP/1.0 200 OK Content-Type: text/html; charset=ISO-8859-1 Connection: close HTTP/1.0 200 OK Content-Type: text/html; charset=ISO-8859-1 Connection: close (press Enter) HTTP/1.0 200 OK Content-Type: text/html; charset=ISO-8859-1 Connection: close