本文只简单实现使用swoole搭建HTTP服务器实例,建议仅作为应用服务器。并且在前端增加Nginx作为代理,具体流程参数配置详情请参照swoole官网。
程序代码
HttpServer.php
use Swoole\Http\Server;
//创建http_server服务器 监听127.0.0.1:8811端口
$http = new Server('0.0.0.0',8811);
//监听http请求 $request 为http请求对象 $response为http响应对象
$http->on('request',function ($request,$response){
print_r($request->get); //获取请求get数据
$response->cookie('houguang','very good',120); //设置客户端cookie
$response->end("<h1>Http-server</h1>".$request->get['age']); //end方法响应返回内容
});
//开启httpserver服务
$http->start();
这里主要创建http_server服务器,IP地址设成4个0内外网都能访问测试,监听8811端口,当某个连接向服务器发起请求时会执行onRequest事件,执行回调函数参数包括http请求对象,http响应对象,能调用相关的方法。
onRequest事件
$http_server->on(‘request’, function(swoole_http_request $request, swoole_http_response $response) {
$response->end(“hello swoole”);
})
在收到一个完整的Http请求后,会回调此函数。回调函数共有2个参数:
- $request,Http请求信息对象,包含了header/get/post/cookie等相关信息
- $response,Http响应对象,支持cookie/header/status等Http操作
- 在onRequest回调函数返回时底层会销毁 r e q u e s t 和 request和 request和response对象,如果未执行$response->end()操作,底层会自动执行一次request()->end(’’);
测试
启动http_server服务
php HttpServer.php
1、使用curl 直接访问测试
2、通过浏览器访问
- 创建服务器监听的8811端口,防火墙端口必须开放此端口
- 修改/etc/sysconfig/iptables (如果没有此文件则安装iptables)
yum install iptables #规则表容器
yum install iptables-services #iptables服务
systemctl stop firewalld #停止自带的firewalld防火墙服务
- 添加-A INPUT -p tcp --dport 8811 -j ACCEPT 保存
- 重启防火墙 service iptables restart
浏览器访问
HttpServer服务器
如果通过http地址请求静态资源,例如访问http://x.x.x.x:8811/index.html,直接将静态资源内容返回给客户端,类似于apache与nginx服务器处理静态资源,不走php处理逻辑,设置方法如下:
//设置请求访问静态资源自动查找文件目录
//设置document_root并设置enable_static_handler为true后,
//底层收到Http请求会先判断document_root路径下是否存在此文件
//如果存在会直接发送文件内容给客户端,不再触发onRequest回调
$http->set([
'enable_static_handler'=>true,
//配置静态文件根目录
'document_root'=>'/home/learn/bd_git/swoole_learn/demo/data'
]);
测试访问