我正在尝试检查文件(图像)是否存在,以便我可以在上传新文件之前将其删除。这是我到目前为止所尝试的:
foreach (glob("../imgs/" . $name . ".*") as $file) {
if (file_exists($file)) {
unlink($file);
}
}
这是正确的做法吗?如果找到匹配,我是否需要打破循环?如果该文件夹中有很多图片,这会表现不好吗?
编辑:对不起,我应该提到这一点:在上传时,文件会被用户唯一ID重命名,这就是为什么如果用户想要上传另一个图像我想用现有图像替换它。 (此图像用于个人资料图片)。
答案 0 :(得分:5)
如果你想打破循环,在<Audit id:110,
auditable_id:4,
auditable_type:"Order",
user_id:1,
user_type:"User",
username:nil,
action:"create",
created_at:"2018-04-07 09:06:20">,
#<Audit id:49,
auditable_id:3,
auditable_type:"Order",
user_id:3,
user_type:"User",
username:nil,
action:"create",
created_at:"2018-04-06 12:28:41">
函数之后添加break statement
:
unlink()
如果要检查PHP文件仅存在:
您可以使用foreach (glob("../imgs/" . $name . ".*") as $file) {
if (file_exists($file)) {
unlink($file);
break;
}
}
功能。如果文件存在,此函数返回file_exist()
,否则返回TRUE
。
FALSE
如果要检查PHP文件是否存在且可读:
您可以使用$filename = './file_name.txt';
if(file_exists($filename)){
echo sprintf('file %s exists',$filename);
}else{
echo sprintf('file %s does not exist',$filename);
}
功能。如果文件存在且可读,则函数返回is_readable()
,否则返回TRUE
。
FALSE
如果要检查PHP文件是否存在且可写:
您可以使用$filename = './file_name.txt';
if(is_readable($filename)){
echo sprintf('file %s exists and readable',$filename);
}else{
echo sprintf('file %s does not exist or is not readable',$filename);
}
功能。如果文件存在且可写,则函数返回is_writable()
,否则返回TRUE
。
FALSE
答案 1 :(得分:3)
是的,你的方法对我来说很好。它最有可能比使用正则表达式获取所有文件名和检查名称更快。
正如Gufran在他的评论中已经提到的那样,在取消链接后放一个休息时间,所以循环不会继续搜索。 只做这个,如果你不打算找到多个文件,那个名字(即test.gif,test.png),那你就得把它留下来。