PHP:如何将dBase文件从内存写入FTP

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

我想直接从内存中保存ftp服务器上的dBase文件。我使用以下简化的代码段。 dBase文件也存储在服务器上 - 但它是空的。

我做错了什么?

有没有办法在没有先在本地保存文件然后通过ftp传输它的情况下这样做?

$ftp_conn = ftp_connect($ftpserver);
ftp_login($ftp_conn, $user, $password);
ftp_chdir($ftp_conn, $destination);
$memstream = fopen('php://memory', 'r+');
if ($myClass->create($memstream)) {       // my function around dbase_create() 
    $numRecords = count($myData); 
    if ($numRecords) {
        $myClass->open();                 // my function around dbase_open()
        foreach ($myData as $myRec) {
            $myClass->addRecord($myRec);  // my function around dbase_add_record()
        }
        $myClass->close();                // my function around dbase_close()
        /** the following lines are for debugging
          * they are delivering correct data -
          * so there is still access to the dBase file 
          **/
        $fritzAdr->open();
        print_r($fritzAdr->getRecord(1);
        $fritzAdr->close();
        $fritzAdr->open();
        print_r($fritzAdr->getRecord($fritz->countRecords())
        $fritzAdr->close();
        // but the $memstream is empty!
        rewind($memstream);
        ftp_fput($ftp_conn, 'filename.dbf',  $memstream, FTP_BINARY);
    }
fclose($memstream);
ftp_close($ftp_conn);
php ftp in-memory dbase
2个回答
0
投票

您可能需要在上传之前“关闭”数据库:

$myClass->close();                // my wrapper around dbase_close()
if ($numRecords) {
    rewind($memstream);
    ftp_fput($ftp_conn, 'filename.dbf',  $memstream, FTP_BINARY);
}

您还应该考虑将数据库直接保存到FTP流,而不是通过创建临时内存流来浪费内存和时间:

$stream = fopen("ftp://$user:$password/$ftpserver/$destination/filename.dbf", 'r+');

Generate CSV file on an external FTP server in PHP


0
投票

最后,我编写了自己的类,可以生成所需的dBase III文件:https://github.com/BlackSenator/fritzadr,它以所需的方式工作:

$memstream = fopen('php://memory', 'r+');
if ($numRecords) {
    $fritzAdr = new fritzadr();
    foreach ($faxContacts as $faxContact) {
        $fritzAdr->addRecord($faxContact);
    }
    fputs($memstream, $fritzAdr->getDatabase());
    rewind($memstream);
    ftp_fput($ftp_conn, 'fritzadr.dbf', $memstream, FTP_BINARY);
}
fclose($memstream);
ftp_close($ftp_conn);
© www.soinside.com 2019 - 2024. All rights reserved.