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 传输。

注意:

此参数仅在 Event 使用 OpenSSL 支持编译且仅在 Libevent 2.1.0-alpha 及更高版本中可用。

变更日志

版本 描述
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
* (按 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
* (按 Enter)
*
* 它将输出:
* HTTP/1.0 200 OK
* Content-Type: text/html; charset=ISO-8859-1
* Connection: close
* (按 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__, " 被调用\n";
echo
"请求:"; var_dump($req);
echo
"数据:"; var_dump($data);

echo
"\n===== 转储 ===== \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
添加注释

用户贡献的注释 2 条注释

Bas Vijfwinkel
9 年前
如果您尝试使用 SSL 上下文参数并收到错误提示您使用了 2 个参数而不是 1 个,那么您的 libevent 库版本不够新,无法支持所有功能。
使用 PECL 安装 event 扩展时,libevent 库需要特定版本才能支持某些函数。
PECL 不会显示任何错误或警告,但会简单地禁用 libevent 版本不支持的所有内容。

有关更多详细信息,请参阅我在以下位置的评论:
https://php.net/manual/en/event.examples.php
匿名
9 年前
此演示代码存在内存泄漏
To Top