ftp_nb_fput

(PHP 4 >= 4.3.0, PHP 5, PHP 7, PHP 8)

ftp_nb_fputArmazena um arquivo de um arquivo aberto no servidor FTP (sem bloqueio)

Descrição

ftp_nb_fput(
    FTP\Connection $ftp,
    string $remote_filename,
    resource $stream,
    int $mode = FTP_BINARY,
    int $offset = 0
): int

ftp_nb_fput() carrega os dados de um ponteiro de arquivo para um arquivo remoto no servidor FTP.

A diferença entre esta função e ftp_fput() é que esta função envia o arquivo de forma assíncrona, para que a aplicação possa realizar outras operações enquanto o arquivo está sendo enviado.

Parâmetros

ftp

Uma instância de FTP\Connection.

remote_filename

O caminho do arquivo remoto.

stream

Um ponteiro de arquivo local aberto. A leitura encerra no final do arquivo.

mode

O modo de transferência. Deve ser FTP_ASCII ou FTP_BINARY.

offset

A posição no arquivo remoto para iniciar o envio.

Valor Retornado

Retorna FTP_FAILED ou FTP_FINISHED ou FTP_MOREDATA.

Registro de Alterações

Versão Descrição
8.1.0 O parâmetro ftp agora espera uma instância de FTP\Connection; anteriormente, um resource era esperado.
7.3.0 O parâmetro mode agora é opcional. Antigamente era obrigatório.

Exemplos

Example #1 Exemplo de ftp_nb_fput()

<?php

$file = 'index.php';

$fp = fopen($file, 'r');

$ftp = ftp_connect($ftp_server);

$login_result = ftp_login($ftp, $ftp_user_name, $ftp_user_pass);

// Inicia o envio
$ret = ftp_nb_fput($ftp, $file, $fp, FTP_BINARY);
while ($ret == FTP_MOREDATA) {

   // Faz alguma coisa
   echo ".";

   // Continua o envio...
   $ret = ftp_nb_continue($ftp);
}
if ($ret != FTP_FINISHED) {
   echo "Houve um erro ao enviar o arquivo...";
   exit(1);
}

fclose($fp);
?>

Veja Também

  • ftp_nb_put() - Armazena um arquivo no servidor FTP (sem bloqueio)
  • ftp_nb_continue() - Continua a receber/enviar um arquivo (sem bloquear)
  • ftp_put() - Envia um arquivo para o servidor FTP
  • ftp_fput() - Envia um arquivo aberto para o servidor FTP