我不确定为什么我可以从目录中读取文件而不能写入。它位于共享网络路径上。
我已经从我的网络团队确认;修改权限";已经为用户帐户准备好了。
以下是我用来检查文件路径是否有效的内容:
<?php
$filename = '//server-name/folder1/folder1/folder3/filename.txt';
if (file_exists($filename)) {echo "good";}
else{echo "bad";}
?>
使用以上内容,我能够得到";"好";在控制台中。
然后我使用了以下内容,看看我是否可以列出目录中的所有文件:
<?php
$dir = '//server-name/folder1/folder2/folder3';
$files1 = scandir($dir);
$files2 = scandir($dir, 1);
print_r($files1);
print_r($files2);
?>
使用以上内容,我成功地打印出了目录中的所有文件。
这是我遇到问题的代码:
<?php
$filename = "newfile";
$thecall = mysqli_query($dbc, "CALL SP_SVC_ALLOCATION($servicecodes)");
$out = array();
while($row = $thecall->fetch_assoc()){
$out[] = $row;
}
$file = fopen("//server-name/folder1/folder2/folder3/$filename.txt", 'w');
foreach ($out as $fields) {
fputcsv($file, $fields);
}
if($file){$result = "File was uploaded";}
else{$result = "File failed to upload";}
?>
使用以上内容,输出为"0";文件上传失败;。
为什么我可以从路径读取,但不能上传?
如前所述,我得到保证,权限已经设置好了。我需要获得共享网络驱动器的完全权限吗?
事实证明,网络路径没有用户的完全权限。它已经更新,现在我可以上传到路径没有问题。
试试这个:
$file = fopen("//server-name/folder1/folder2/folder3/$filename.txt", 'w');
$csv="";
foreach ($out as $fields){
$csv.= implode(',',$fields)."n";
}
fwrite($file,$csv);
fclose($file);