PHP 8.1.0 RC 2 available for testing


(PHP 4, PHP 5, PHP 7, PHP 8)

ftp_fgetTélécharge un fichier via FTP dans un fichier local


    resource $ftp,
    resource $stream,
    string $remote_filename,
    int $mode = FTP_BINARY,
    int $offset = 0
): bool

ftp_fget() télécharge le fichier remote_filename depuis le serveur FTP et l'écrit dans le fichier identifié par stream.

Liste de paramètres


L'identifiant du lien de connexion FTP.


Un pointeur de fichier ouvert dans lequel on écrit les données.


Le chemin vers le fichier distant.


Le mode de transfert. Doit être soit FTP_ASCII, soit FTP_BINARY.


La position du fichier distant à partir de laquelle le téléchargement commence.

Valeurs de retour

Cette fonction retourne true en cas de succès ou false si une erreur survient.


Version Description
7.3.0 Le paramètre mode est maintenant optionel. Précédemment il était obligatoire.


Exemple #1 Exemple avec ftp_fget()


// Chemin vers le fichier distant
$remote_file 'somefile.txt';
$local_file 'localfile.txt';

// Ouverture du fichier pour écriture
$handle fopen($local_file'w');

// Mise en place d'une connexion basique
$conn_id ftp_connect($ftp_server);

// Identification avec un nom d'utilisateur et un mot de passe
$login_result ftp_login($conn_id$ftp_user_name$ftp_user_pass);

// Tente de téléchargement le fichier $remote_file et de le sauvegarder dans $handle
if (ftp_fget($conn_id$handle$remote_fileFTP_ASCII0)) {
"Ecriture dans le fichier $local_file avec succès\n";
} else {
"Il y a un problème lors du téléchargement du fichier $remote_file dans $local_file\n";

// Fermeture de la connexion et du pointeur de fichier

Voir aussi

  • ftp_get() - Télécharge un fichier depuis un serveur FTP
  • ftp_nb_get() - Lit un fichier sur un serveur FTP, et l'écrit dans un fichier (non bloquant)
  • ftp_nb_fget() - Lit un fichier sur un serveur FTP, et l'écrit dans un fichier (non bloquant)

add a note add a note

User Contributed Notes 6 notes

broom at alturnanetworks dot com
12 years ago
Another ftp_get_contents approach, using a temperary stream handler. Returns file contents as string.

function ftp_get_contents ($conn_id, $filename,
//Create temp handler:
$tempHandle = fopen('php://temp', 'r+');

//Get file from FTP assuming that it exists:
ftp_fget($conn_id, $tempHandle, $filename, FTP_ASCII, 0));

//Getting detailed stats to check filesize:
$fstats = fstat($tempHandle);

fread($tempHandle, $fstats['size']);
broom at alturnanetworks dot com
12 years ago
* Function returns contents via FTP connection and returns it as string (right version...)
function ftp_get_contents ($conn_id, $filename) {
//Create temp handler:
$tempHandle = fopen('php://temp', 'r+');
//Get file from FTP:
if (@ftp_fget($conn_id, $tempHandle, $filename, FTP_ASCII, 0)) {
    } else {
mike at eastghost dot com
8 years ago
You might need to use ftp_pasv() if you're behind a firewall and receiving odd timeouts, file creation but now local data saving, etc.
lionskape at gmail dot com
4 years ago
if you are using windows ftp-server with cp1251 encoding there are some troubles with russian "я" in filename\path.

php use telnet to connect ftp-server and there are special symbol with code 255 in telnet protocol. You can try use ftp_raw($connection, 'OPTS UTF8 ON'); and work in utf-8 (if server provides it).

P.S. sorry for my bad english
rodrigo-rocha at oi dot net dot br
19 years ago
If you suply only a filename to the second parameter of function the ftp_get will open a pointer to the local file creating it and write to it.It's ok if your server dont execute for to mutch time and you dont get too many files but if you do it too many times the pointers created by ftp_get will not be closed and will end your opened files capacity at your server making it to do not open any more files until you restart it.
justrafi at gmail dot com
13 years ago
I was in need to synchronize two folders on two separate servers, one is a Windows server, and the other is a Linux server. I created this short and sweet function to help me do this. PLEASE NOTICE: This will not copy folders, and probably will fail if remote folder contains anything else than files.

function sync_folders($host, $port, $username, $password, $remote_dir, $local_dir, $passive_mode = true) {
    $conn_id = ftp_connect($host, $port);
    if (!$conn_id) return false; # fail to connect
    if (!ftp_login($conn_id, $username, $password)) { ftp_close($conn_id); return false; }  # fail to login
    ftp_pasv($conn_id, $passive_mode);
    if (!ftp_chdir($conn_id, $remote_dir)) { ftp_close($conn_id); return false; } # fail to change dir
    if (substr($local_dir, -1) != '/') $local_dir .= '/';

    $list = ftp_nlist($conn_id, '.');
    foreach ($list as $file) {
        if (!file_exists($local_dir . $file)) {
            $is_copied = ftp_get($conn_id, $local_dir . $file, $file, FTP_BINARY);
    return true;
To Top