php 文件操作详解

虽说这是很基础的东西,惭愧的是我却对此并不是很了解。所以借此温故了一下

文件操作

文件进行写操作的步骤

  1. 打开这个文件。如果文件不存在,那么创建它。
  2. 创建文件锁,防止并发
  3. 将这些数据写入这个文件
  4. 释放锁,并且关闭文件句柄

文件进行读操作的步骤

  1. 打开这个文件,如果不能打开就退出
  2. 从文件中读取数据
  3. 关闭这个文件

打开文件操作

fopen($filename,$mode,$include_path,$context)

打开失败返回false 打开成功则返回资源对象。

属性名称作用
$filename文件的路径(文件路径的间隔符用‘/’来表示,用’\’可能会导致linux不识别)
$mode文件访问的形式(写
$include_path(可选)从指定目录开始寻找文件所在位置
$context可选。规定文件句柄的环境。Context 是可以修改流的行为的一套选项。

注意:
- 当文件的前缀是ftp://即文件服务器时 如果我们开启了 allow_url_fopen 配置的话,该函数将会建立一个连接到指定服务器的被动模式。并返回一个指向文件开始位置的指针
- 当文件前缀是http://时,会建立一个到指定服务器的http连接,返回一个纸箱http响应的指针
- 在Linux时执行文件操作要注意服务器的权限配置。

操作符模式名称意义
r读模式打开文件从头开始
r+读写模式打开文件,从文件头开始读写
w只写模式打开文件,从文件头开始读写。如文件存在,清空文件内容,如不存在则创建文件
w+读写模式同上
x谨慎写如果文件存在则返回false
x+谨慎写以读写方式打开文件,如果文件存在则返回false
a追加在文件末尾进行写操作
a+追加在文件末尾进行读写操作

写文件操作

A. 需要调用 fopen()函数

1.`fwrite()`

描述 `int fwrite ( resource $handle , string $string [, int $length ] )`
$string   写入的字符  
$length   限制写入的长度

B . 不需要调用fopen()函数

1. file_put_contents()
描述 file_put_contents(file,data,mode,context)
相当于一句话执行
fopen(),fwrite(),fclose()

关闭文件

fclose($fp)

如果成功返回true,反之false

读操作

$fp = fopen('./test.php','a')//以只读方式打开
flock($fp,LOCK_SH);//读操作锁定
while(!feof($fp))
{
    $order = fgets($fp);
    echo $order
}
fclose($fp)//关闭文件
# feof($fp) //检测文件是否读取到文件结束标志
//文件读写的几种操作
/*读取一行内的文字*/
# fgets($fp)  //获取文件一行字符
# (更加安全的操作,过滤了php和html标签)fgetss($fp,10,'<a>')//三个参数 1.文件资源 2.限制每次获取的长度(如为0则不限制长度) 3.允许通过的标签
# fgetcsv($fp,0,"/t") 以"/t"为分隔符,分割我数组
/*读取整个文件*/
# (不需要fopen()操作) readfile ( string $filename [, bool $use_include_path = false [, resource $context ]] )  //返回文件字符长度,!!!并且直接把内容输出到浏览器上
# fpassthru( resource $handle )  //返回boolean值
# file ( string $filename [, int $flags = 0 [, resource $context ]] )//把整个文件读入一个数组中,对每一行作为一个元素保存
/*读取一个字符*/
# fgetc()
/*读取任意长度字符*/
# fread($fp,$legth)

其他文件函数

file_exists("路径");   //文件是否存在
filesize("路径"); //文件大小
unlink;     //删除文件

文件锁

函数:`fclock($fp,’操作值’);//开启锁

操作值意义
LOCK_SH读操作锁定,可以共享,其他人可以读该文件
LOCK_EX写操作锁定,互斥锁
LOCK_UN释放已有的锁
LOCK_NB防止在请求枷锁时发生柱塞

目录操作

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值