在PHP脚本中,无论是调用include(), require(), fopen(),还是它们的衍生物,如include_once, require_once,甚至move_uploaded_file(),都经常会遇到错误或警告:

无法打开流:没有这样的文件或目录。

什么是快速找到问题根源的良好流程?


当前回答

Samba股票

如果您有一个Linux测试服务器,并且从Windows客户端工作,那么Samba共享会干扰chmod命令。所以,即使你使用:

chmod -R 777 myfolder

在Linux方面,Unix组\www-data仍然没有写权限是完全可能的。如果您的共享设置为Windows管理员映射到根目录,一个可行的解决方案是:在Windows中,打开权限,禁用带有副本的文件夹的继承,然后授予www-data的完全访问权限。

其他回答

添加带有查询参数的脚本

那是我的案子。它实际上链接到问题#4485874,但我将在这里简短地解释它。 当你试图要求路径/到/script.php?参数=值,PHP查找名为script.php的文件?parameter=value,因为UNIX允许您使用这样的路径。 如果你真的需要传递一些数据到包含的脚本,只需声明它为$variable=…或全局美元[]=…或者其他你喜欢的方式。

无法打开流:在mac中没有这样的文件或目录

例如,我会上传一张图片。但是我得到了这个错误。第一件事,我会做右键点击图像和获取信息。

$ thepathofmpicture = "/Users/misstugba/Desktop/"; 配合功能使用

if(move_uploaded_file($_FILES["file"]["tmp_name"],$thePathOfMyPicture.$_FILES["file"]["name"])){
echo "image uploaded successfully";

}

Samba股票

如果您有一个Linux测试服务器,并且从Windows客户端工作,那么Samba共享会干扰chmod命令。所以,即使你使用:

chmod -R 777 myfolder

在Linux方面,Unix组\www-data仍然没有写权限是完全可能的。如果您的共享设置为Windows管理员映射到根目录,一个可行的解决方案是:在Windows中,打开权限,禁用带有副本的文件夹的继承,然后授予www-data的完全访问权限。

对我来说,我得到了这个错误,因为我试图读取一个需要HTTP认证的文件,有用户名和密码。希望能帮助别人。可能是另一个极端情况。

Edit

你可以通过检查头文件来检查是否存在这种类型的身份验证:

$file_headers = get_headers($url);
if (!$file_headers) echo 'File headers missing';
else if (strpos($file_headers[0], '401 Unauthorized') > -1) echo '401 Unauthorized';

除了其他精彩的回答,在Windows上写一个简单的脚本时,我忽略了一件事:当试图打开一个带有Windows不支持的文件名字符的文件时,会出现这个错误。

例如:

$file = fopen(date('Y-m-d_H:i:s'), 'w+');

将:

fopen(2022-06-01_22:53:03): Failed to open stream: No such file or directory in…

Windows不喜欢:在文件名中,以及其他一些字符。