PHP特殊类型—资源(文件)

PHP第一种特殊类型—资源

资源(resource):资源是由专门的函数来建立和使用的,例如打开文件、数据连接、图形画布。我们可以对资源进行操作(创建、使用和释放)。任何资源,在不需要的时候应该被及时释放。如果我们忘记了释放资源,系统自动启用垃圾回收机制,在页面执行完毕后回收资源,以避免内存被消耗殆尽。

举个栗子:

<?php
$file=fopen("f.txt","r");   //打开文件
$con=mysql_connect("localhost","root","root");  //连接数据库
$img=imagecreate(100,100);//图形画布
?>

假设服务器上有一个文件(f.txt),你想看看里面有什么好东西,就可以采用资源这种数据类型。

具体代码:

<?php 
//首先采用“fopen”函数打开文件,得到返回值的就是资源类型。
$file_handle=fopen("/data/webroot/resource/php/f.txt","r");
if ($file_handle){//文件打开成功
//接着采用while循环一行行地读取文件
//然后输出每行的文字
    while (!feof($file_handle)) { //判断是否到最后一行
        $line = fgets($file_handle); //读取一行文本
        echo $line; //输出一行文本
        echo "<br />"; //换行
    }
}
fclose($file_handle);//关闭文件
?>

运行结果:
在这里插入图片描述

那么关于这段代码,有几个函数,需要研究一哈," fopen(),feof() , fgets() ,fclose() "

1.fopen():

定义和用法:
        fopen() 函数打开文件或者 URL 如果打开失败,本函数返回 FALSE
语法:
        fopen( filename , mode , include_path , context )

参数 描述
filename 必需。规定要打开的文件或 URL
mode 必需。规定要求到该文件/流的访问类型。可能的值见下表。
include_path 可选。如果也需要在 include_path 中检索文件的话,可以将该参数设为 1 或 TRUE。
context 可选。规定文件句柄的环境。Context 是可以修改流的行为的一套选项。

include_path   (path英文意思路径)
        其实设置include_path的作用就是设置用include()函数包函文件时的路径,当然也可以不设置include_path,只要在包函文件时写出具体的文件相对或绝对路即可:
        include_path用来设置include()或require()函数包含文件的参考路径. 也就是说当使用include()或require()函数包含文件的时候,程序首先以include_path设置的路径作为参考点去找文件,如果找不到,则以程序自身所在的路径为参考点去找所要的文件,如果都找不到,则出错.
        当include_path设置了多个参考路径(每个路径用分号隔开)时,排在前面的路径优先找.
例如:
         ini_set(‘include_path’,‘d:\www\mysite\test;d:\www\mysite\test2’);
        include(‘aaa/test.php’);
        程序会先以路径d:\www\mysite\test为参考去找aaa/test.php,若没有,再以d:\www\mysite\test2为参考去找,再没有,则以自身所在路径为参考去找.

context    (英文意思:上下文,语境,环境,背景)
具体参考网站:https://www.php.net/manual/zh/context.php

mode 参数的可能的值:

mode 说明
“r” 只读方式打开,将文件指针指向文件头。
“r+” 读写方式打开,将文件指针指向文件头。
“w” 写入方式打开,将文件指针指向文件头并将文件大小截为零。如果文件不存在则尝试创建之。
“w+” 读写方式打开,将文件指针指向文件头并将文件大小截为零。如果文件不存在则尝试创建之。
“a” 写入方式打开,将文件指针指向文件末尾。如果文件不存在则尝试创建之。
“a+” 读写方式打开,将文件指针指向文件末尾。如果文件不存在则尝试创建之。
“x” 创建并以写入方式打开,将文件指针指向文件头。如果文件已存在,则 fopen() 调用失败并返回 FALSE,并生成一条 E_WARNING 级别的错误信息。如果文件不存在则尝试创建之。这和给底层的 open(2) 系统调用指定 O_EXCL
“x+” 创建并以读写方式打开,将文件指针指向文件头。如果文件已存在,则 fopen() 调用失败并返回 FALSE,并生成一条 E_WARNING 级别的错误信息。如果文件不存在则尝试创建之。这和给底层的 open(2) 系统调用指定 O_EXCL

说明:

        fopen() 将 filename 指定的名字资源绑定到一个流上。如果 filename 是 “scheme://…” 的格式,则被当成一个 URL,PHP 将搜索协议处理器(也被称为封装协议)来处理此模式。如果该协议尚未注册封装协议,PHP 将发出一条消息来帮助检查脚本中潜在的问题并将 filename 当成一个普通的文件名继续执行下去。
        如果 PHP 认为 filename 指定的是一个本地文件,将尝试在该文件上打开一个流。该文件必须是 PHP 可以访问的,因此需要确认文件访问权限允许该访问。如果激活了安全模式或者 open_basedir 则会应用进一步的限制。
        如果 PHP 认为 filename 指定的是一个已注册的协议,而该协议被注册为一个网络 URL,PHP 将检查并确认 allow_url_fopen 已被激活。如果关闭了,PHP 将发出一个警告,而 fopen 的调用则失败。
         对 context 的支持是 PHP 5.0.0 添加的。

提示和注释:

        注释:不同的操作系统家族具有不同的行结束习惯。当写入一个文本文件并想插入一个新行时,需要使用符合操作系统的行结束符号。基于 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” 模式。

例子:

<?php
$file = fopen("test.txt","r");
$file = fopen("/home/test/test.txt","r");
$file = fopen("/home/test/test.gif","wb");
$file = fopen("http://www.example.com/","r");
$file = fopen("ftp://user:[email protected]/test.txt","w");
?>

2.feof():

作用:

        测试文件指针是否到了文件结束的位置

说明:

 feof ( resource $handle ) : bool

测试文件指针是否到了文件结束的位置

参数:

handle
      文件指针必须是有效的,必须指向由 fopen() 或 fsockopen() 成功打开的文件(并还未由 fclose() 关闭)。
      关于fsockpen()参考:https://www.php.net/manual/zh/function.fsockopen.php

返回值:

      如果文件指针到了 EOF 或者出错时则返回 TRUE,否则返回一个错误(包括 socket 超时),其它情况则返回 FALSE。

注释:

Warning :
      如果服务器没有关闭由 fsockopen() 所打开的连接,feof() 会一直等待直到超时。
      如果传递的文件指针无效可能会陷入无限循环中,因为 feof() 不会返回 TRUE。

3.fgets():

定义和用法:

fgets() 函数从打开的文件中返回一行。
fgets() 函数会在到达指定长度( length - 1 )、碰到换行符、读到文件末尾(EOF)时(以先到者为准),停止返回一个新行。
如果失败该函数返回 FALSE。

语法:

fgets(file,length)
参数 描述
file 必需。规定要读取的文件。
length 可选。规定要读取的字节数。默认是 1024 字节。

案例代码:

<?php
$file = fopen("test.txt","r");
 
while(! feof($file))
{
    echo fgets($file). "<br />";
}
 
fclose($file);
?>

4.fclose():

定义和用法:

fclose() 函数关闭一个打开文件。

语法:

 fclose(file)
参数 描述
file 文件名,必需。规定要关闭的文件。

说明:

file 参数是一个文件指针。fclose() 函数关闭该指针指向的文件。
如果成功则返回 true,否则返回 false。
文件指针必须有效,并且是通过 fopen() 或 fsockopen() 成功打开的。

发布了17 篇原创文章 · 获赞 1 · 访问量 896

猜你喜欢

转载自blog.csdn.net/weixin_43914604/article/details/97240069