Condividi tramite


Funzione FtpGetFileW (wininet.h)

Recupera un file dal server FTP e lo archivia con il nome file specificato, creando un nuovo file locale nel processo.

Sintassi

BOOL FtpGetFileW(
  [in] HINTERNET hConnect,
  [in] LPCWSTR   lpszRemoteFile,
  [in] LPCWSTR   lpszNewFile,
  [in] BOOL      fFailIfExists,
  [in] DWORD     dwFlagsAndAttributes,
  [in] DWORD     dwFlags,
  [in] DWORD_PTR dwContext
);

Parametri

[in] hConnect

Handle in una sessione FTP.

[in] lpszRemoteFile

Puntatore a una stringa con terminazione Null contenente il nome del file da recuperare.

[in] lpszNewFile

Puntatore a una stringa con terminazione Null contenente il nome del file da creare nel sistema locale.

[in] fFailIfExists

Indica se la funzione deve continuare se esiste già un file locale del nome specificato. Se fFailIfExists è true e il file locale esiste, FtpGetFile ha esito negativo.

[in] dwFlagsAndAttributes

Attributi di file per il nuovo file. Questo parametro può essere qualsiasi combinazione dei flag FILE_ATTRIBUTE_* usati dalla funzione CreateFile.

[in] dwFlags

Controlla la modalità di gestione del download del file da parte della funzione. Il primo set di valori di flag indica le condizioni in cui si verifica il trasferimento. Questi flag di tipo di trasferimento possono essere usati in combinazione con il secondo set di flag che controllano la memorizzazione nella cache.

L'applicazione può selezionare uno di questi valori di tipo di trasferimento.

Valore Significato
FTP_TRANSFER_TYPE_ASCII
Trasferisce il file usando il metodo di trasferimento ASCII (Type A) ftp. Le informazioni di controllo e formattazione vengono convertite in equivalenti locali.
FTP_TRANSFER_TYPE_BINARY
Trasferisce il file usando il metodo di trasferimento Image (Type I) ftp. Il file viene trasferito esattamente come esiste senza modifiche. Si tratta del metodo di trasferimento predefinito.
FTP_TRANSFER_TYPE_UNKNOWN
Il valore predefinito è FTP_TRANSFER_TYPE_BINARY.
INTERNET_FLAG_TRANSFER_ASCII
Trasferisce il file come ASCII.
INTERNET_FLAG_TRANSFER_BINARY
Trasferisce il file come binario.
 

I flag seguenti determinano come verrà eseguita la memorizzazione nella cache di questo file. Qualsiasi combinazione dei flag seguenti può essere usata con il flag del tipo di trasferimento.

Valore Significato
INTERNET_FLAG_HYPERLINK
Forza un ricaricamento se non è presente un'ora di scadenza e non viene restituito alcun tempo LastModified dal server per determinare se ricaricare l'elemento dalla rete.
INTERNET_FLAG_NEED_FILE
Determina la creazione di un file temporaneo se il file non può essere memorizzato nella cache.
INTERNET_FLAG_RELOAD
Forza un download del file, dell'oggetto o dell'elenco di directory richiesto dal server di origine, non dalla cache.
INTERNET_FLAG_RESYNCHRONIZE
Ricarica le risorse HTTP se la risorsa è stata modificata dall'ultima volta che è stata scaricata. Tutte le risorse FTP vengono ricaricate.

anche le risorse di Windows XP e Windows Server 2003 R2 e versioni precedenti: vengono ricaricate anche le risorse di Gopher .

[in] dwContext

Puntatore a una variabile che contiene il valore definito dall'applicazione che associa la ricerca a tutti i dati dell'applicazione. Viene usato solo se l'applicazione ha già chiamato InternetSetStatusCallback per configurare una funzione di callback di stato.

Valore restituito

Restituisce TRUE in caso di esito positivo oppure FALSE in caso contrario. Per ottenere un messaggio di errore specifico, chiamare GetLastError.

Osservazioni

FtpGetFile è una routine di alto livello che gestisce tutte le operazioni di contabilità e sovraccarico associate alla lettura di un file da un server FTP e all'archiviazione locale. Un'applicazione che deve recuperare solo i dati dei file o che richiede un controllo stretto sul trasferimento di file deve usare le funzioni ftpOpenFile e InternetReadFile.

Se il parametro dwFlags specifica FTP_TRANSFER_TYPE_ASCII, la conversione dei dati dei file converte i caratteri di controllo e formattazione in equivalenti locali. Il trasferimento predefinito è la modalità binaria, in cui il file viene scaricato nello stesso formato archiviato nel server.

Sia lpszRemoteFile che lpszNewFile possono essere nomi di file parzialmente o completi relativi alla directory corrente.

Come tutti gli altri aspetti dell'API WinINet, questa funzione non può essere chiamata in modo sicuro dall'interno di DllMain o dai costruttori e distruttori di oggetti globali.

Nota WinINet non supporta le implementazioni del server. Inoltre, non deve essere usato da un servizio. Per le implementazioni del server o i servizi, usare Servizi HTTP Di Microsoft Windows (WinHTTP).
 

Nota

L'intestazione wininet.h definisce FtpGetFile come alias che seleziona automaticamente la versione ANSI o Unicode di questa funzione in base alla definizione della costante del preprocessore UNICODE. La combinazione dell'utilizzo dell'alias indipendente dalla codifica con il codice non indipendente dalla codifica può causare mancate corrispondenze che generano errori di compilazione o di runtime. Per altre informazioni, vedere convenzioni di per i prototipi di funzioni.

Fabbisogno

Requisito Valore
client minimo supportato Windows 2000 Professional [solo app desktop]
server minimo supportato Windows 2000 Server [solo app desktop]
piattaforma di destinazione Finestre
intestazione wininet.h
libreria Wininet.lib
dll Wininet.dll

Vedere anche

sessioni FTP

funzioni WinINet