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

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

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


当前回答

添加带有查询参数的脚本

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

其他回答

看看准确的误差

我的代码在所有机器上都工作得很好,但只有在这一台机器上开始出现问题(我猜过去是这样的)。使用echo“document_root”路径进行调试,并仔细查看了错误,发现了这个

警告: 包括(D: / MyProjects / testproject / /功能/ connections.php): 打开流失败:

你很容易就能看出问题在哪里。问题在函数之前

$document_root = $_SERVER['DOCUMENT_ROOT'];
echo "root: $document_root";
include($document_root.'/functions/connections.php');

因此,只需从include中删除提单/,它就可以正常工作。有趣的是这种行为在不同的版本上是不同的。我在笔记本电脑,Macbook Pro和这台PC上运行相同的代码,都工作得很好,直到。希望这能帮助到一些人。

复制过去浏览器中的文件位置,以确保文件存在。有时文件会被意外删除(发生在我身上),这也是我的情况。

对我来说,我得到了这个错误,因为我试图读取一个需要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';

添加带有查询参数的脚本

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

下面的PHP设置在PHP .ini中如果设置为不存在的目录也会引发

PHP警告:未知:未能打开流:权限被拒绝 第0行未知

sys_temp_dir
upload_tmp_dir
session.save_path

除了其他精彩的回答,在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不喜欢:在文件名中,以及其他一些字符。