swoole_client->recv

最后更新于:2022-04-02 06:36:43

# swoole\_client->recv [TOC] recv方法用于从服务器端接收数据。接受2个参数。函数原型为: ~~~ //低于1.7.22 string $swoole_client->recv(int $size = 65535, bool $waitall = 0); //1.7.22或更高 string $swoole_client->recv(int $size = 65535, int $flags = 0); ~~~ * $size,接收数据的缓存区最大长度,此参数不要设置过大,否则会占用较大内存 * $waitall,是否等待所有数据到达后返回 > 如果设定了$waitall就必须设定准确的$size,否则会一直等待,直到接收的数据长度达到`$size` > 未设置`$waitall=true`时,$size最大为`64K` > 如果设置了错误的$size,会导致`recv`超时,返回**false** * 成功收到数据返回字符串 * 连接关闭返回空字符串 * 失败返回**false**,并设置`$client->errCode`属性 ## EOF/Length 客户端启用了EOF/Length检测后,无需设置$size和$waitall参数。扩展层会返回完整的数据包或者返回false。 * 当收到错误的包头或包头中长度值超过`package_max_length`设置时,`recv`会返回空字符串,PHP代码中应当关闭此连接 ## Flags 1.7.22版本后,第二个`$waitall`参数修改为`$flags`,可以接收一些特殊的SOCKET接收设置。为了兼容旧的接口,如果$flags=1则表示 $flags = swoole\_client::MSG\_WAITALL ~~~ $client->recv(8192, swoole_client::MSG_PEEK | swoole_client::MSG_WAITALL); ~~~
';