PHPerKaigi 2025

stream_get_line

(PHP 5, PHP 7, PHP 8)

stream_get_line从资源流里读取一行直到给定的定界符

说明

stream_get_line(resource $stream, int $length, string $ending = ""): string|false

从给定的资源流里读取一行。

当读取到 length 个字节数就结束,或者当在读取的非空字符串中发现 ending包含到返回值里)也结束,又或者遇到了 EOF 也结束(总之以上条件中哪个先出现就以哪个为准)。

这个函数与 fgets() 几乎是相同的,唯一的区别是在这个函数里面允许指定行尾的定界符,而不是使用标准的 \n, \r 还有 \r\n ,并且返回值中包含定界符。(翻译注:也可以把 \n 等作为定界符传入 ending

参数

stream

一个有效的文件句柄。

length

需要从句柄中读取的最大字节数。不支持负值。 0 表示默认的套接字块大小(socket chunk size),即 8192 字节。

ending

可选参数,字符串定界符。

返回值

返回一个字符串,该字符串的内容根据 length 字节数从 stream 里读取, 或者在失败时返回 false

参见

  • fread() - 读取文件(可安全用于二进制文件)
  • fgets() - 从文件指针中读取一行
  • fgetc() - 从文件指针中读取字符
添加备注

用户贡献的备注 1 note

up
12
pk at ritm dot ru
15 years ago
fgets is faster but stream_get_line is more useful in a tcp server scripts.

when fgets reads some bytes from socket, where EOF is reached, it returns bool(false) same as stream_get_line

BUT if remote client drops connection, and server script will try to read some data with function fgets, function will return bool(false), and stream_get_line will return string(0) ""

so you can detect remote client disconnection with stream_get_line, and cannot with fgets
To Top