download feito
Apenas tive de indicar que utiliza TLS Explicito.
//Codigo baseado no exemplo de uso de FTP TLS Explicito do componente Chilkat
Chilkat.SFtp sftp = new Chilkat.SFtp();
success = sftp.UnlockComponent("Anything for 30-day trial");
if (success != true) {
MessageBox.Show(sftp.LastErrorText);
return;
}
// Set some timeouts, in milliseconds:
sftp.ConnectTimeoutMs = 5000;
sftp.IdleTimeoutMs = 15000;
// Connect to the SSH server.
// The standard SSH port = 22
// The hostname may be a hostname or IP address.
int port;
string hostname;
hostname = "141.61.102.16";
port = 1299;
success = sftp.Connect(hostname,port);
if (success != true) {
MessageBox.Show(sftp.LastErrorText);
return;
}
// Authenticate with the SSH server. Chilkat SFTP supports
// both password-based authenication as well as public-key
// authentication. This example uses password authenication.
success = sftp.AuthenticatePw("myLogin","myPassword");
if (success != true) {
MessageBox.Show(sftp.LastErrorText);
return;
}
// After authenticating, the SFTP subsystem must be initialized:
success = sftp.InitializeSftp();
if (success != true) {
MessageBox.Show(sftp.LastErrorText);
return;
}
// Open a file on the server:
string handle;
handle = sftp.OpenFile("download.txt","readOnly","openExisting");
if (handle == null ) {
MessageBox.Show(sftp.LastErrorText);
return;
}
byte[] pData = null;
bool bEof;
bEof = false;
int chunkSize;
chunkSize = 10000;
while (bEof == false) {
pData = sftp.ReadFileBytes(handle,chunkSize);
if (sftp.LastReadFailed(handle) == true) {
MessageBox.Show(sftp.LastErrorText);
break;
}
else {
}
bEof = sftp.Eof(handle);
}
// Close the file.
success = sftp.CloseHandle(handle);
if (success != true) {
MessageBox.Show(sftp.LastErrorText);
return;
}
MessageBox.Show("Success.");