fopen 打开文件或者 URL
发表日期:2021-07-01 08:55:42 | 来源: | | 浏览(1123) 分类:文件系统函数
fopen
(PHP 4, PHP 5, PHP 7, PHP 8)
fopen — 打开文件或者 URL
说明
string
$filename
,string
$mode
,bool
$use_include_path
= false,resource
$context
= ?): resource
fopen() 将
filename
指定的名字资源绑定到一个流上。
参数
-
filename
-
如果
filename
是 "scheme://..." 的格式,则被当成一个 URL,PHP 将搜索协议处理器(也被称为封装协议)来处理此模式。如果该协议尚未注册封装协议,PHP 将发出一条消息来帮助检查脚本中潜在的问题并将filename
当成一个普通的文件名继续执行下去。如果 PHP 认为
filename
指定的是一个本地文件,将尝试在该文件上打开一个流。该文件必须是 PHP 可以访问的,因此需要确认文件访问权限允许该访问。如果激活了 open_basedir 则会应用进一步的限制。如果 PHP 认为
filename
指定的是一个已注册的协议,而该协议被注册为一个网络 URL,PHP 将检查并确认 allow_url_fopen 已被激活。如果关闭了,PHP 将发出一个警告,而 fopen 的调用则失败。注意:
所支持的协议列表见支持的协议和封装协议。某些协议(也被称为
wrappers
)支持context
和/或 php.ini 选项。参见相应的页面哪些选项可以被设定(例如 php.ini 中用于http
wrapper 的user_agent
值)。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
-
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'
.注意:
不同的操作系统家族具有不同的行结束习惯。当写入一个文本文件并想插入一个新行时,需要使用符合操作系统的行结束符号。基于 Unix 的系统使用
\n
作为行结束字符,基于 Windows 的系统使用\r\n
作为行结束字符,基于 Macintosh 的系统使用\r
作为行结束字符。如果写入文件时使用了错误的行结束符号,则其它应用程序打开这些文件时可能会表现得很怪异。
Windows 下提供了一个文本转换标记(
't'
)可以透明地将\n
转换为\r\n
。与此对应还可以使用'b'
来强制使用二进制模式,这样就不会转换数据。要使用这些标记,要么用'b'
或者用't'
作为mode
参数的最后一个字符。默认的转换模式依赖于 SAPI 和所使用的 PHP 版本,因此为了便于移植鼓励总是指定恰当的标记。如果是操作纯文本文件并在脚本中使用了
\n
作为行结束符,但还要期望这些文件可以被其它应用程序例如 Notepad 读取,则在 mode 中使用't'
。在所有其它情况下使用'b'
。在操作二进制文件时如果没有指定
'b'
标记,可能会碰到一些奇怪的问题,包括坏掉的图片文件以及关于\r\n
字符的奇怪问题。注意:
为移植性考虑,强烈建议在用 fopen() 打开文件时总是使用
'b'
标记。注意:
再一次,为移植性考虑,强烈建议你重写那些依赖于
't'
模式的代码使其使用正确的行结束符并改成'b'
模式。 -
use_include_path
-
如果也需要在 include_path 中搜寻文件的话,可以将可选的第三个参数
use_include_path
设为 '1' 或true
。 -
context
-
注意: 在 PHP 5.0.0 中增加了对上下文(Context)的支持。有关
上下文(Context)
的说明参见 Streams。
返回值
成功时返回文件指针资源,如果打开失败,本函数返回 false
。
错误/异常
如果打开失败,会产生一个 E_WARNING
错误。可以通过 @ 来屏蔽错误。
更新日志
版本 | 说明 |
---|---|
4.3.2 |
自 PHP 4.3.2
起,对所有区别二进制和文本模式的平台默认模式都被设为二进制模式。如果在升级后脚本碰到问题,尝试暂时使用
't' 标记,直到所有的脚本都照以下所说的改为更具移植性以后。
|
4.3.2 |
增加了选项 'x' 和 'x+'
|
5.2.6 |
增加了选项 'c' 和 'c+'
|
范例
示例 #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"); ?>
注释
使用 SSL 时,Microsoft IIS
会违反协议不发送close_notify
标记就关闭连接。PHP 会在到达数据尾端时报告“SSL: Fatal Protocol Error”。
要解决此问题,error_reporting 应设定为降低级别至不包含警告。
PHP 4.3.7 及更高版本可以在使用 https://
包装器打开流时检测出有问题的 IIS 服务器软件 并抑制警告。在使用
fsockopen() 创建 ssl://
套接字时, 开发者需检测并抑制此警告。
注意:
如果在用服务器模块版本的 PHP 时在打开和写入文件上遇到问题,记住要确保所使用的文件和目录是服务器进程所能够访问的。
注意:
This function may also succeed when
filename
is a directory. If you are unsure whetherfilename
is a file or a directory, you may need to use the is_dir() function before calling fopen().
参见
- 支持的协议和封装协议
- 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
- PHP(0)
- PHP杂项(34)
- PHP基础-李炎恢系列课程(20)
- 中文函数手册(0)
- 错误处理 函数(13)
- OPcache 函数(6)
- PHP 选项/信息 函数(54)
- Zip 函数(10)
- Hash 函数(15)
- OpenSSL 函数(63)
- Date/Time 函数(51)
- 目录函数(9)
- Fileinfo 函数(6)
- iconv 函数(11)
- 文件系统函数(81)
- basename 返回路径中的文件名部分(0)
- chgrp 改变文件所属的组(0)
- chmod 改变文件模式(0)
- chown 改变文件的所有者(0)
- clearstatcache 清除文件状态缓存(0)
- copy 拷贝文件(0)
- delete 参见 unlink() 或 unset()(0)
- dirname 返回路径中的目录部分(0)
- disk_free_space 返回目录中的可用空间(0)
- disk_total_space 返回一个目录的磁盘总大小(0)
- diskfreespace disk_free_space() 的别名(0)
- fclose 关闭一个已打开的文件指针(0)
- feof 测试文件指针是否到了文件结束的位置(0)
- fflush 将缓冲内容输出到文件(0)
- fgetc 从文件指针中读取字符(0)
- fgetcsv 从文件指针中读入一行并解析 CSV 字段(0)
- fgets 从文件指针中读取一行(0)
- fgetss 从文件指针中读取一行并过滤掉 HTML 标记(0)
- file_exists 检查文件或目录是否存在(0)
- file_get_contents 将整个文件读入一个字符串(0)
- file_put_contents 将一个字符串写入文件(0)
- file 把整个文件读入一个数组中(0)
- fileatime 取得文件的上次访问时间(0)
- filectime 取得文件的 inode 修改时间(0)
- filegroup 取得文件的组(0)
- fileinode 取得文件的 inode(0)
- filemtime 取得文件修改时间(0)
- fileowner 取得文件的所有者(0)
- fileperms 取得文件的权限(0)
- filesize 取得文件大小(0)
- filetype 取得文件类型(0)
- flock 轻便的咨询文件锁定(0)
- fnmatch 用模式匹配文件名(0)
- fopen 打开文件或者 URL(0)
- fpassthru 输出文件指针处的所有剩余数据(0)
- fputcsv 将行格式化为 CSV 并写入文件指针(0)
- fputs fwrite() 的别名(0)
- fread 读取文件(可安全用于二进制文件)(0)
- fscanf 从文件中格式化输入(0)
- fseek 在文件指针中定位(0)
- fstat 通过已打开的文件指针取得文件信息(0)
- ftell 返回文件指针读/写的位置(0)
- ftruncate 将文件截断到给定的长度(0)
- fwrite 写入文件(可安全用于二进制文件)(0)
- glob 寻找与模式匹配的文件路径(0)
- is_dir 判断给定文件名是否是一个目录(0)
- is_executable 判断给定文件名是否可执行(0)
- is_file 判断给定文件名是否为一个正常的文件(0)
- is_link 判断给定文件名是否为一个符号连接(0)
- is_readable 判断给定文件名是否可读(0)
- is_uploaded_file 判断文件是否是通过 HTTP POST 上传的(0)
- is_writable 判断给定的文件名是否可写(0)
- is_writeable is_writable() 的别名(0)
- lchgrp 修改符号链接的所有组(0)
- lchown 修改符号链接的所有者(0)
- link 建立一个硬连接(0)
- linkinfo 获取一个连接的信息(0)
- lstat 给出一个文件或符号连接的信息(0)
- mkdir 新建目录(0)
- move_uploaded_file 将上传的文件移动到新位置(0)
- parse_ini_file 解析一个配置文件(0)
- parse_ini_string 解析配置字符串(0)
- pathinfo 返回文件路径的信息(0)
- pclose 关闭进程文件指针(0)
- popen 打开进程文件指针(0)
- readfile 输出文件(0)
- readlink 返回符号连接指向的目标(0)
- realpath_cache_get 获取真实目录缓存的详情(0)
- realpath_cache_size 获取真实路径缓冲区的大小(0)
- realpath 返回规范化的绝对路径名(0)
- rename 重命名一个文件或目录(0)
- rewind 倒回文件指针的位置(0)
- rmdir 删除目录(0)
- set_file_buffer stream_set_write_buffer() 的别名(0)
- stat 给出文件的信息(0)
- symlink 建立符号连接(0)
- tempnam 建立一个具有唯一文件名的文件(0)
- tmpfile 建立一个临时文件(0)
- touch 设定文件的访问和修改时间(0)
- umask 改变当前的 umask(0)
- unlink 删除文件(0)
- 多字节字符串 函数(57)
- GD 和图像处理 函数(114)
- 可交换图像信息(5)
- Math 函数(50)
- 程序执行函数(11)
- PCNTL 函数(23)
- JSON 函数(4)
- SPL 函数(15)
- URL 函数(10)
- cURL 函数(32)
- 网络 函数(33)
- FTP 函数(36)
- Session 函数(23)
- PCRE 函数(11)
- PCRE 正则语法(19)
- 数组 函数(81)
- 类/对象 函数(18)
- 函数处理 函数(13)
- 变量处理 函数(37)
- SimpleXML 函数(3)
- 杂项 函数(31)
- 字符串 函数(101)