在PHP脚本中,无论是调用include(), require(), fopen(),还是它们的衍生物,如include_once, require_once,甚至move_uploaded_file(),都经常会遇到错误或警告:
无法打开流:没有这样的文件或目录。
什么是快速找到问题根源的良好流程?
在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不喜欢:在文件名中,以及其他一些字符。