PHP基础-文件操作

文件引用

PHP文件可以引用另外一个文件的内容,使用方法为【include】或【require】

语法
include 'test.php';

或者

require 'test.php';

引用语句错误处理方式

语句名称错误处理方式
require生成一个致命错误(E_COMPILE_ERROR),在错误发生后脚本会停止执行。
include生成一个警告(E_WARNING),在错误发生后脚本会继续执行。

示例

test.php

<?php
echo "小猫在河边钓鱼<br>";
include 'test2.php';
echo "小狗在河里游泳";
?>

test2.php

<?php
echo "松鼠在树上玩耍<br>";
?>

执行test.php结果

小猫在河边钓鱼
松鼠在树上玩耍
小狗在河里游泳

文件处理

文件处理函数释义
fopen()打开文件
fclose()关闭文件
feof()检测是否读取完毕
fgets()逐字符读取文件
fwrite()写入文件
move_uploaded_file()移动上传文件
copy()复制文件
unlink ()删除指定文件

fopen()

语法

打开文件

fopen("文件名[绝对路径]","处理模式");

fopen("test.txt", "r") 

为了防止打开失败,可以这样写

fopen("test.txt", "r") or die("Unable to open file!");

fopen("test.txt","r") or exit("Unable to open file!")
处理模式
模式描述
r只读。在文件的开头开始。
r+读/写。在文件的开头开始。
w只写。打开并清空文件的内容;如果文件不存在,则创建新文件。
w+读/写。打开并清空文件的内容;如果文件不存在,则创建新文件。
a追加。打开并向文件末尾进行写操作,如果文件不存在,则创建新文件。
a+读/追加。通过向文件末尾写内容,来保持文件内容。
x只写。创建新文件。如果文件已存在,则返回 FALSE 和一个错误。
x+读/写。创建新文件。如果文件已存在,则返回 FALSE 和一个错误。

fclose()

关闭文件

<?php
$file = fopen("test.txt","r");

//执行一些代码

fclose($file);
?>

feof()

feof() 函数检测是否已到达文件末尾(EOF)。

在循环遍历未知长度的数据时,feof() 函数很有用。

注释:在 w 、a 和 x 模式下,您无法读取打开的文件!

if (feof($file)) echo "文件结尾";

fgets()

fgets() 函数用于从文件中逐行读取文件。

注:在调用该函数之后,文件指针会移动到下一个字符。

逐行文本读取
<?php

    $content = fopen('welcome.txt', 'r');
    $combine_content = "";

    while (!feof($content)) {
        $content_line = fgets($content, 4096);
        echo $content_line;
    }
        fclose($content);
?>
逐行文本读取加入到数组
<?php

    $content = fopen("aa.txt","r");
	$arr = array();
	$i = 0;
	while ($str[$i] = fgets($content)) {
        $i++;
    }
	$arr = array_filter($str);
	print_r($arr);
	fclose($content); 
?>

fwrite()

fwrite()用于写入文件,如果命名文件不存在则创建该文件

<?php
$text = "人生若只如初见,何事秋风悲画扇。\n";
$file = fopen("3.txt","a");

fwrite($file,$text)
?>

move_uploaded_file()

move_uploaded_file()函数适用于文件保存【即上传到临时目录的文件移动到指定目录】

语法

move_uploaded_file(file,newloc)
参数描述
file必需。规定要移动的文件。
newloc必需。规定文件的新位置。

示例:将上传的文件移动到指定目录

move_uploaded_file($_FILES["file"]["tmp_name"], "upload/" . $_FILES["file"]["name"]);

copy()

拷贝文件示例

copy ( 'dir1/1.txt','dir2/' )

unlink ()

删除文件示例

unlink ( '3.txt' )

文件上传

PHP文件上传是实现了获取文件对象和写入文件到服务器的操作。

文件上传示例

form 提交上传文件
<html>
<head><meta http-equiv="Content-Type" content="text/html; charset=utf-8" /></head>
<body>
    <form action="upload_file.php" method="post" enctype="multipart/form-data">
        文件名:
        <input type="file" name="file"><br>
        <input type="submit" value="提交">
    </form>
</body>
</html>
获取上传文件信息
<?php
if ($_FILES["file"]["error"] > 0)
{
    echo "错误:" . $_FILES["file"]["error"] . "<br>";
}
else
{
    print_r($_FILES["file"]);
    echo "上传文件名: " . $_FILES["file"]["name"] . "<br>";
    echo "文件类型: " . $_FILES["file"]["type"] . "<br>";
    echo "文件大小: " . ($_FILES["file"]["size"] / 1024) . " kB<br>";
    echo "文件临时存储的位置: " . $_FILES["file"]["tmp_name"];
}
?>
保存文件
<?php

if ($_FILES["file"]["error"] > 0) {
    echo "错误:" . $_FILES["file"]["error"] . "<br>";
} else {
    move_uploaded_file($_FILES["file"]["tmp_name"], "./dir1/" . $_FILES["file"]["name"]);
}

?>
上传限制
<?php
// 允许上传的图片后缀
$allowedExts = array("gif", "jpeg", "jpg", "png");
$temp = explode(".", $_FILES["file"]["name"]);
$extension = end($temp);        // 获取文件后缀名
if ((($_FILES["file"]["type"] == "image/gif")
|| ($_FILES["file"]["type"] == "image/jpeg")
|| ($_FILES["file"]["type"] == "image/jpg")
|| ($_FILES["file"]["type"] == "image/pjpeg")
|| ($_FILES["file"]["type"] == "image/x-png")
|| ($_FILES["file"]["type"] == "image/png"))
&& ($_FILES["file"]["size"] < 204800)    // 小于 200 kb
&& in_array($extension, $allowedExts))
{
    if ($_FILES["file"]["error"] > 0)
    {
        echo "错误:: " . $_FILES["file"]["error"] . "<br>";
    }
    else
    {
        echo "上传文件名: " . $_FILES["file"]["name"] . "<br>";
        echo "文件类型: " . $_FILES["file"]["type"] . "<br>";
        echo "文件大小: " . ($_FILES["file"]["size"] / 1024) . " kB<br>";
        echo "文件临时存储的位置: " . $_FILES["file"]["tmp_name"];
    }
}
else
{
    echo "非法的文件格式";
}
?>
上传文件(包含上传限制)
<?php
// 允许上传的图片后缀
$allowedExts = array("gif", "jpeg", "jpg", "png");
$temp = explode(".", $_FILES["file"]["name"]);
echo $_FILES["file"]["size"];
$extension = end($temp);     // 获取文件后缀名
if ((($_FILES["file"]["type"] == "image/gif")
|| ($_FILES["file"]["type"] == "image/jpeg")
|| ($_FILES["file"]["type"] == "image/jpg")
|| ($_FILES["file"]["type"] == "image/pjpeg")
|| ($_FILES["file"]["type"] == "image/x-png")
|| ($_FILES["file"]["type"] == "image/png"))
&& ($_FILES["file"]["size"] < 204800)   // 小于 200 kb
&& in_array($extension, $allowedExts))
{
    if ($_FILES["file"]["error"] > 0)
    {
        echo "错误:: " . $_FILES["file"]["error"] . "<br>";
    }
    else
    {
        echo "上传文件名: " . $_FILES["file"]["name"] . "<br>";
        echo "文件类型: " . $_FILES["file"]["type"] . "<br>";
        echo "文件大小: " . ($_FILES["file"]["size"] / 1024) . " kB<br>";
        echo "文件临时存储的位置: " . $_FILES["file"]["tmp_name"] . "<br>";
        
        // 判断当期目录下的 upload 目录是否存在该文件
        // 如果没有 upload 目录,你需要创建它,upload 目录权限为 777
        if (file_exists("upload/" . $_FILES["file"]["name"]))
        {
            echo $_FILES["file"]["name"] . " 文件已经存在。 ";
        }
        else
        {
            // 如果 upload 目录不存在该文件则将文件上传到 upload 目录下
            move_uploaded_file($_FILES["file"]["tmp_name"], "upload/" . $_FILES["file"]["name"]);
            echo "文件存储在: " . "upload/" . $_FILES["file"]["name"];
        }
    }
}
else
{
    echo "非法的文件格式";
}
?>

扩展

文件上传中文乱码

利用iconv()函数进行编码转置存储

<?php
        $upload_file = iconv("UTF-8", "GBK", $_FILES["myfile"]["name"]);   //先转换名字为 GBK 编码
        if (move_uploaded_file($_FILES["myfile"]["tmp_name"], $upload_file)) {
                $res_file = iconv("GBK", "UTF-8", $upload_file);    // 再从 GBK 转为 UTF-8
                rename($upload_file, $res_file);   // 重命名一下文件
                echo "<strong>upload ok</strong><hr>";
        } else {
                echo "upload failed";
        }
  
?>
filesize()函数判断文件是否为空

判断文件 test.txt 是否为空

<?php
echo filesize("test.txt");
?>

转载于:https://my.oschina.net/zhaojunhui/blog/3085100

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值