EventHttp::__construct

(PECL event >= 1.2.6-beta)

EventHttp::__constructСоздаёт объект EventHttp (HTTP-сервер)

Описание

public EventHttp::__construct( EventBase $base , EventSslContext $ctx = null )

Создаёт объект 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 
$sPHP_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 <= || $port 65535) {
    exit(
"Неверный порт");
}

$base = new EventBase();
$http = new EventHttp($base);
$http->setAllowedMethods(EventHttpRequest::CMD_GET EventHttpRequest::CMD_POST);

$http->setCallback("/dump""_http_dump", array(48));
$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
add a note add a note

User Contributed Notes 2 notes

up
0
Bas Vijfwinkel
8 years ago
If you try to use the SSL context parameter and you receive an error that you're using 2 parameters instead of 1, then your libevent library is not recent enough to support all features.
When installing the event extension with PECL, the libevent library needs a certain version to support certain functions.
PECL does not show any errors or warnings but simple disables everything that your libevent version does not support.

For further details see my comment at
http://php.net/manual/en/event.examples.php
up
0
Anonymous
9 years ago
This demo code has a memory leak
To Top