(PHP 4, PHP 5, PHP 7)
fopen — 打开文件或者 URL
说明
$filename
,
string $mode
[,
bool $use_include_path
= false [,
resource $context
]] )
fopen() 将 filename
指定的名字资源绑定到一个流上。
参数
-
如果
filename
是 "scheme://..." 的格式,则被当成一个 URL,PHP 将搜索协议处理器(也被称为封装协议)来处理此模式。如果该协议尚未注册封装协议,PHP 将发出一条消息来帮助检查脚本中潜在的问题并将filename
当成一个普通的文件名继续执行下去。如果 PHP 认为
filename
指定的是一个本地文件,将尝试在该文件上打开一个流。该文件必须是 PHP 可以访问的,因此需要确认文件访问权限允许该访问。如果激活了安全模式或者 open_basedir 则会应用进一步的限制。如果 PHP 认为
filename
指定的是一个已注册的协议,而该协议被注册为一个网络 URL,PHP 将检查并确认allow_url_fopen 已被激活。如果关闭了,PHP 将发出一个警告,而 fopen 的调用则失败。On the Windows platform, be careful to escape any backslashes used in the path to the file, or use forward slashes.
<?php
$handle = fopen("c:\\folder\\resource.txt", "r");
?> -
mode
参数指定了所要求到该流的访问类型。可以是以下:fopen() 中 mode
的可能值列表mode
说明 'r' 只读方式打开,将文件指针指向文件头。 'r+' 读写方式打开,将文件指针指向文件头。 'w' 写入方式打开,将文件指针指向文件头并将文件大小截为零。如果文件不存在则尝试创建之。 'w+' 读写方式打开,将文件指针指向文件头并将文件大小截为零。如果文件不存在则尝试创建之。 'a' 写入方式打开,将文件指针指向文件末尾。如果文件不存在则尝试创建之。 'a+' 读写方式打开,将文件指针指向文件末尾。如果文件不存在则尝试创建之。 'x' 创建并以写入方式打开,将文件指针指向文件头。如果文件已存在,则 fopen() 调用失败并返回 FALSE
,并生成一条E_WARNING
级别的错误信息。如果文件不存在则尝试创建之。这和给 底层的open(2) 系统调用指定 O_EXCL|O_CREAT 标记是等价的。'x+' 创建并以读写方式打开,其他的行为和 'x' 一样。 'c' Open the file for writing only. If the file does not exist, it is created. If it exists, it is neither truncated (as opposed to 'w'), nor the call to this function fails (as is the case with 'x'). The file pointer is positioned on the beginning of the file. This may be useful if it's desired to get an advisory lock (see flock()) before attempting to modify the file, as using 'w' could truncate the file before the lock was obtained (if truncation is desired, ftruncate() can be used after the lock is requested). 'c+' Open the file for reading and writing; otherwise it has the same behavior as 'c'. -
如果也需要在 include_path 中搜寻文件的话,可以将可选的第三个参数
use_include_path
设为 '1' 或TRUE
。
filename
mode
use_include_path
context
返回值
成功时返回文件指针资源,如果打开失败,本函数返回 FALSE
。
错误/异常
如果打开失败,会产生一个 E_WARNING
错误。可以通过 @ 来屏蔽错误。
更新日志
版本 | 说明 |
---|---|
4.3.2 | 自 PHP 4.3.2 起,对所有区别二进制和文本模式的平台默认模式都被设为二进制模式。如果在升级后脚本碰到问题,尝试暂时使用 't' 标记,直到所有的脚本都照以下所说的改为更具移植性以后。 |
4.3.2 | 增加了选项 'x' 和 'x+' |
5.2.6 | 增加了选项 'c' 和 'c+' |
范例
Example #1 fopen() 例子
<?php
$handle = fopen("/home/rasmus/file.txt", "r");
$handle = fopen("/home/rasmus/file.gif", "wb");
$handle = fopen("http://www.example.com/", "r");
$handle = fopen("ftp://user:password@example.com/somefile.txt", "w");
?>
注释
参见
- 支持的协议和封装协议
- fclose() - 关闭一个已打开的文件指针
- fgets() - 从文件指针中读取一行
- fread() - 读取文件(可安全用于二进制文件)
- fwrite() - 写入文件(可安全用于二进制文件)
- fsockopen() - 打开一个网络连接或者一个Unix套接字连接
- file() - 把整个文件读入一个数组中
- file_exists() - 检查文件或目录是否存在
- is_readable() - 判断给定文件名是否可读
- stream_set_timeout() - Set timeout period on a stream
- popen() - 打开进程文件指针
- stream_context_create() - 创建资源流上下文
- umask() - 改变当前的 umask
- SplFileObject