0

0

PHP创建文件如何避免重复_判断文件是否存在的正确方式【技巧】

雪夜

雪夜

发布时间:2026-02-21 19:47:03

|

269人浏览过

|

来源于php中文网

原创

应先用 realpath() 标准化路径再 file_exists();防重复创建须用 fopen('x')、touch() 或 file_put_contents(file_excl);判断存在性用 file_exists(),而非 is_file() 或 !is_dir()。

php创建文件如何避免重复_判断文件是否存在的正确方式【技巧】

file_exists() 判断前先确认路径是否合法

很多开发者直接对用户传入的文件名调用 file_exists(),结果在路径含 ../、空格、中文或未转义斜杠时返回 false,误判为“文件不存在”。这不是函数失效,而是 PHP 在解析路径时已出错或被安全机制拦截。

实操建议:

  • realpath() 先标准化路径,再判断。它会解析符号链接、折叠 .././,失败时返回 false,可提前捕获非法路径
  • 检查 dirname() 对应目录是否存在且可写(is_dir() + is_writable()),避免文件路径合法但父目录不可写导致创建失败
  • Windows 下注意大小写不敏感,Linux 下严格区分,跨平台项目别依赖大小写判断“重复”

fopen()x 模式是原子级防重创建的关键

靠先 file_exists()fopen(..., 'w') 是典型竞态漏洞:两次调用之间可能被其他进程/线程抢先创建同名文件,导致覆盖或逻辑错乱。

正确做法是跳过判断,直接用独占创建模式:

立即学习PHP免费学习笔记(深入)”;

$fp = fopen('/path/to/file.txt', 'x');
if ($fp === false) {
    // 文件已存在,或目录不可写,或磁盘满
    $error = error_get_last()['message'] ?? 'unknown';
    if (strpos($error, 'File exists') !== false) {
        // 真正的“重复”场景
    }
}

'x' 模式只在文件**完全不存在**时成功打开并返回句柄,否则立即失败,无中间状态。它底层调用的是系统级的 O_EXCL | O_CREAT,是 POSIX 标准保证的原子操作。

音刻
音刻

AI音视频转录和笔记工具

下载

创建前用 touch()file_put_contents() 配合 FILE_EXCL 更简洁

如果只需创建空文件,touch() 最简;若要写内容,file_put_contents()FILE_EXCL 标志效果等同于 fopen('x'),且自动处理关闭。

示例:

// 创建空文件,失败说明已存在
$result = touch('/path/to/file.log');

// 写入内容,仅当文件不存在时成功
$result = file_put_contents('/path/to/data.json', '{"a":1}', LOCK_EX | FILE_EXCL);
if ($result === false) {
    // 可能是文件已存在,也可能是权限/磁盘问题
    // 建议再用 file_exists() + is_writable() 细分原因
}

注意:FILE_EXCL 仅在目标文件**完全不存在**时生效;若文件存在但为空,仍会失败——这正是你想要的“防重复”行为。

慎用 is_file() 替代 file_exists() 判断“是否存在”

file_exists() 返回 true 对于文件和目录都成立;而 is_file() 只对普通文件返回 true,遇到目录、符号链接、设备文件等均返回 false。如果你本意是“防止同名文件被覆盖”,却用了 is_file(),那同名目录存在时就会误判为“可创建”,最终 fopen('x') 失败或 file_put_contents() 报错 Is a directory

所以:

  • 判断“能否创建同名文件” → 用 file_exists() 或直接上 'x' 模式
  • 判断“某路径是否为普通文件” → 才用 is_file()
  • 永远不要用 is_dir() 的反向逻辑代替 file_exists()

真正容易被忽略的点是:PHP 的文件系统函数多数不抛异常,失败只返回 false,且错误信息藏在 error_get_last() 里——不主动查,就永远不知道是“已存在”还是“没权限”或“路径越界”。

相关文章

PHP速学教程(入门到精通)
PHP速学教程(入门到精通)

PHP怎么学习?PHP怎么入门?PHP在哪学?PHP怎么学才快?不用担心,这里为大家提供了PHP速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
线程和进程的区别
线程和进程的区别

线程和进程的区别:线程是进程的一部分,用于实现并发和并行操作,而线程共享进程的资源,通信更方便快捷,切换开销较小。本专题为大家提供线程和进程区别相关的各种文章、以及下载和课程。

695

2023.08.10

windows查看端口占用情况
windows查看端口占用情况

Windows端口可以认为是计算机与外界通讯交流的出入口。逻辑意义上的端口一般是指TCP/IP协议中的端口,端口号的范围从0到65535,比如用于浏览网页服务的80端口,用于FTP服务的21端口等等。怎么查看windows端口占用情况呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

1208

2023.07.26

查看端口占用情况windows
查看端口占用情况windows

端口占用是指与端口关联的软件占用端口而使得其他应用程序无法使用这些端口,端口占用问题是计算机系统编程领域的一个常见问题,端口占用的根本原因可能是操作系统的一些错误,服务器也可能会出现端口占用问题。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

1151

2023.07.27

windows照片无法显示
windows照片无法显示

当我们尝试打开一张图片时,可能会出现一个错误提示,提示说"Windows照片查看器无法显示此图片,因为计算机上的可用内存不足",本专题为大家提供windows照片无法显示相关的文章,帮助大家解决该问题。

823

2023.08.01

windows查看端口被占用的情况
windows查看端口被占用的情况

windows查看端口被占用的情况的方法:1、使用Windows自带的资源监视器;2、使用命令提示符查看端口信息;3、使用任务管理器查看占用端口的进程。本专题为大家提供windows查看端口被占用的情况的相关的文章、下载、课程内容,供大家免费下载体验。

460

2023.08.02

windows无法访问共享电脑
windows无法访问共享电脑

在现代社会中,共享电脑是办公室和家庭的重要组成部分。然而,有时我们可能会遇到Windows无法访问共享电脑的问题。这个问题可能会导致数据无法共享,影响工作和生活的正常进行。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

2361

2023.08.08

windows自动更新
windows自动更新

Windows操作系统的自动更新功能可以确保系统及时获取最新的补丁和安全更新,以提高系统的稳定性和安全性。然而,有时候我们可能希望暂时或永久地关闭Windows的自动更新功能。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

854

2023.08.10

windows boot manager
windows boot manager

windows boot manager无法开机的解决方法:1、系统文件损坏,使用Windows安装光盘或USB启动盘进入恢复环境,选择修复计算机,然后选择自动修复;2、引导顺序错误,进入恢复环境,选择命令提示符,输入命令"bootrec /fixboot"和"bootrec /fixmbr",然后重新启动计算机;3、硬件问题,使用硬盘检测工具进行扫描和修复;4、重装操作系统。本专题还提供其他解决

1878

2023.08.28

pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法
pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法

本专题系统整理pixiv网页版官网入口及登录访问方式,涵盖官网登录页面直达路径、在线阅读入口及快速进入方法说明,帮助用户高效找到pixiv官方网站,实现便捷、安全的网页端浏览与账号登录体验。

928

2026.02.13

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PHP课程
PHP课程

共137课时 | 12.2万人学习

JavaScript ES5基础线上课程教学
JavaScript ES5基础线上课程教学

共6课时 | 11.3万人学习

PHP新手语法线上课程教学
PHP新手语法线上课程教学

共13课时 | 0.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号