Http\Response->detach

最后更新于:2022-04-02 06:33:46

# Http\\Response->detach [TOC] 分离响应对象。使用此方法后,`$response`对象销毁时不会自动`end`,与`Http\Response::create`和`Server::send`配合使用。 ~~~ function Http\Response->detach(); ~~~ * 客户端已完成响应,操作失败返回`false`,成功返回`true` > 需要`2.2.0`或更高版本 ## 跨进程响应 某些情况下,需要在`Task`进程中对客户端发出响应。这时可以利用`detach`使`$response`对象独立。在`Task`进程可以重新构建`$response`,发起`Http`请求响应。 ~~~ $http = new swoole_http_server("0.0.0.0", 9501); $http->set(['task_worker_num' => 1, 'worker_num' => 1]); $http->on('request', function ($req, Swoole\Http\Response $resp) use ($http) { $resp->detach(); $http->task(strval($resp->fd)); }); $http->on('finish', function () { echo "task finish"; }); $http->on('task', function ($serv, $task_id, $worker_id, $data) { var_dump($data); $resp = Swoole\Http\Response::create($data); $resp->end("in task"); echo "async task\n"; }); $http->start(); ~~~ ## 发送任意内容 某些特殊的场景下,需要对客户端发送特殊的响应内容。`Http\Response`对象自带的`end`方法无法满足需求,可以使用`detach`分离响应对象,然后自行组包并使用`Server::send`发送数据。 ~~~ $http = new swoole_http_server("0.0.0.0", 9501); $http->on('request', function ($req, Swoole\Http\Response $resp) use ($http) { $resp->detach(); $http->send($resp->fd, "HTTP/1.1 200 OK\r\nServer: server\r\n\r\nHello World\n"); }); $http->start(); ~~~
';