0
$host = 'XXXXXXXXXXX'
$usr = 'XXXXXXXXXXX';
$pwd = 'XXXXXXXXXXX';
$destDir = $_POST['filetype'];
$conn_id=ftp_connect($host);
$success = ftp_login($conn_id,$usr,$pwd);
$rightName = basename($_FILES['uploadfile']['name']);
ftp_pasv($conn_id, true);
if($success)
{ 
    ftp_put($conn_id,$destDir.'/'.$rightName,$_FILES['uploadfile']['tmp_name'],FTP_BINARY) or die('Cannot ftp');
    ftp_close($conn_id);
    echo ' Upload Successful';
} 

表格在这里

<form enctype="multipart/form-data" action="upload.php" method="POST">
    <input name="filetype" id="filetype1" /><br />
    <input name="uploadfile" type="file" /><br />
<input type="submit" value="Upload File" />

我尝试了多种选择。'ftp_put' 从 php 的 tmp 上传位置到工作目录,然后到目标目录和 'ftp_put' 直接从 PHP 的临时上传目录到所需目录,但 FTP 出于某种原因似乎根本不起作用。它只是简单地死去。使用“move_uploaded_files()”的正常上传效果很好。在一些论坛中提到要让 ftp 工作,我不能有“文件”输入类型,而只有一个纯文本框。我不明白为什么会这样,或者即使它是真的。为什么上面的代码不起作用?我已经检查了目标文件夹的权限,这应该不是问题。

更新

抱歉,问题是由于文档问题。文档中提到的 FTP 根不正确,代码中使用的 FTP 根与文档中的 FTP 根不同,因此出现了问题。

4

1 回答 1

0

在 PHP 中移动文件是一件棘手的事情,因为有几件事情一起玩。

  1. 目标目录必须可由服务器进程写入。
  2. PHP 具有安全特性。其中之一称为安全模式。安全模式检查(除其他事项外)文件的 UID 和 GID(用户 ID 和组 ID)并限制例如允许包含哪些文件。以及避免在不属于脚本 UID / GID 的目录中创建它们。通常,您上传的用户不是运行网络服务器的用户。因此,例如,当您创建一个目录时,它是使用网​​络服务器 UID/GID 创建的,并且无法通过具有不同的 PHP 脚本在其中创建文件UID/GID。
于 2013-07-16T15:22:07.217 回答