PHP Conference Japan 2024

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。

注意事項:

此參數僅在以 OpenSSL 支援編譯 Event,且僅適用於 Libevent 2.1.0-alpha 及更高版本時才可用。

更新日誌

版本 說明
PECL event 1.9.0 新增 OpenSSL 支援 (ctx)。

範例

範例 #1 簡易 HTTP 伺服器

<?php
/*
* Simple HTTP server.
*
* To test it:
* 1) Run it on a port of your choice, e.g.:
* $ php examples/http.php 8010
* 2) In another terminal connect to some address on this port
* and make GET or POST request(others are turned off here), e.g.:
* $ nc -t 127.0.0.1 8010
* POST /about HTTP/1.0
* Content-Type: text/plain
* Content-Length: 4
* Connection: close
* (press Enter)
*
* It will output
* 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)
*
* It will output:
* 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
*
* It will output:
* HTTP/1.0 200 OK
* Content-Type: text/html; charset=ISO-8859-1
* Connection: close
*
* 3) See what the server outputs on the previous terminal window.
*/

function _http_dump($req, $data) {
static
$counter = 0;
static
$max_requests = 2;

if (++
$counter >= $max_requests) {
echo
"Counter reached max requests $max_requests. Exiting\n";
exit();
}

echo
__METHOD__, " called\n";
echo
"request:"; var_dump($req);
echo
"data:"; var_dump($data);

echo
"\n===== DUMP =====\n";
echo
"Command:", $req->getCommand(), PHP_EOL;
echo
"URI:", $req->getUri(), PHP_EOL;
echo
"Input headers:"; var_dump($req->getInputHeaders());
echo
"Output headers:"; var_dump($req->getOutputHeaders());

echo
"\n >> Sending reply ...";
$req->sendReply(200, "OK");
echo
"OK\n";

echo
"\n >> Reading input buffer ...\n";
$buf = $req->getInputBuffer();
while (
$s = $buf->readLine(EventBuffer::EOL_ANY)) {
echo
$s, PHP_EOL;
}
echo
"No more data in the buffer\n";
}

function
_http_about($req) {
echo
__METHOD__, PHP_EOL;
echo
"URI: ", $req->getUri(), PHP_EOL;
echo
"\n >> Sending reply ...";
$req->sendReply(200, "OK");
echo
"OK\n";
}

function
_http_default($req, $data) {
echo
__METHOD__, PHP_EOL;
echo
"URI: ", $req->getUri(), PHP_EOL;
echo
"\n >> Sending reply ...";
$req->sendReply(200, "OK");
echo
"OK\n";
}

$port = 8010;
if (
$argc > 1) {
$port = (int) $argv[1];
}
if (
$port <= 0 || $port > 65535) {
exit(
"Invalid port");
}

$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", "custom data value");

$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
新增筆記

使用者貢獻的筆記 2 則筆記

Bas Vijfwinkel
9 年前
如果您嘗試使用 SSL context 參數,卻收到錯誤訊息指出您使用了 2 個參數而不是 1 個,則表示您的 libevent 函式庫版本不夠新,無法支援所有功能。
使用 PECL 安裝 event 擴充套件時,libevent 函式庫需要特定版本才能支援某些功能。
PECL 不會顯示任何錯誤或警告,但會直接停用您的 libevent 版本不支援的所有功能。

更多詳細資訊,請參閱我在
https://php.dev.org.tw/manual/en/event.examples.php 的評論
匿名
9 年前
此示範程式碼有記憶體洩漏
To Top