Exemplo
Baixar um arquivo a partir do servidor FTP, e salve-o em um arquivo local aberto (non-blocking) :
<?php
// connect and login to FTP server
$ftp_server = "ftp.example.com";
$ftp_conn = ftp_connect($ftp_server) or
die("Could not connect to $ftp_server");
$login
= ftp_login($ftp_conn, $ftp_username, $ftp_userpass);
$server_file =
"somefile.txt";
// open local file to write to
$local_file =
"local.txt";
$fp = fopen($local_file,"w");
// initiate download
$d = ftp_nb_fget($ftp_conn,
$fp, $server_file, FTP_BINARY)
while ($d == FTP_MOREDATA)
{
// do whatever you want
// continue downloading
$d = ftp_nb_continue($ftp_conn);
}
if ($d != FTP_FINISHED)
{
echo "Error downloading
$server_file";
exit(1);
}
// close connection and file
handler
ftp_close($ftp_conn);
fclose($fp);
?>
Definição e Uso
O ftp_nb_fget() função obtém (downloads) um arquivo do servidor FTP e salva-lo em um arquivo local aberto (non-blocking) .
Dica: Esta função (como oposto ao ftp_fget() ) recupera o arquivo de forma assíncrona, para que possa realizar outras operações enquanto o arquivo está sendo baixado.
Sintaxe
ftp_nb_fget( ftp_connection,open_file,server_file,mode,startpos );
Parâmetro | Descrição |
---|---|
ftp_connection | Requeridos. Especifica a conexão de FTP para usar |
open_file | Requeridos. Especifica um arquivo local aberto, no qual nós armazenamos os dados |
server_file | Requeridos. Especifica o arquivo de servidor para baixar |
mode | Requeridos. Especifica o modo de transferência. Os valores possíveis: FTP_ASCII ou FTP_BINARY |
startpos | Opcional. Especifica a posição no arquivo remoto para iniciar o download a partir de |
Detalhes técnicos
Valor de retorno: | Esta função retorna um dos seguintes valores:
|
---|---|
PHP Versão: | 4.3 + |
<PHP FTP Referência