在PHP中的外部FTP服务器上生成CSV文件

问题描述 投票:3回答:1

我有一些PHP代码可以成功地将MySQL表导出到CSV文件。

我想添加到该代码,因此不是在本地保存,而是将CSL文件导出到/保存在外部FTP服务器上。

我目前的代码:

//open database connection                            
require ('../database-config.php');

//name the file
header('Content-Type: text/csv');
header('Content-Disposition: attachment;filename=exported-data.csv');

//SQL Query for Data
$sql = "SELECT * FROM data;";        
//Prepare Query, Bind Parameters, Excute Query
$STH = $dbh->prepare($sql);
$STH->execute();

//Export to .CSV
$fp = fopen('php://output', 'w');

$first_row = $STH->fetch(PDO::FETCH_ASSOC);
$headers = array_keys($first_row);

fputcsv($fp, $headers); // put the headers
fputcsv($fp, array_values($first_row)); // put the first row

while ($row = $STH->fetch(PDO::FETCH_NUM))  {
fputcsv($fp,$row); // push the rest
}
fclose($fp);

我知道我需要添加一些新的变量;

$ftp_server="ftp.remotersite.com";
$ftp_path="/path/to/somefile";
$ftp_username="username";
$ftp_userpass="password";

但是,我不确定使用ftp_put(或者它应该是ftp_fput?)转移到外部目的地的最佳方式。

提前致谢。

php ftp export-to-csv fputcsv
1个回答
3
投票

如果你有ftp:// URL wrappers enabled,只需直接在FTP服务器上打开文件:

$fp = fopen('ftp://username:[email protected]/path/to/somefile', 'w');

如果您没有启用包装器,请参阅: Creating and uploading a file in PHP to an FTP server without saving locally

© www.soinside.com 2019 - 2024. All rights reserved.