Chilkat HOME .NET Core C# Android™ AutoIt C C# C++ Chilkat2-Python CkPython Classic ASP DataFlex Delphi ActiveX Delphi DLL Go Java Lianja Mono C# Node.js Objective-C PHP ActiveX PHP Extension Perl PowerBuilder PowerShell PureBasic Ruby SQL Server Swift 2 Swift 3,4,5... Tcl Unicode C Unicode C++ VB.NET VBScript Visual Basic 6.0 Visual FoxPro Xojo Plugin
(Objective-C) SFTP Get Size of File on ServerSee more SFTP ExamplesDemonstrates how to get the size of an existing file on the server.
#import <CkoSFtp.h> #import <NSString.h> // This example assumes the Chilkat API to have been previously unlocked. // See Global Unlock Sample for sample code. CkoSFtp *sftp = [[CkoSFtp alloc] init]; // Set some timeouts, in milliseconds: sftp.ConnectTimeoutMs = [NSNumber numberWithInt:5000]; sftp.IdleTimeoutMs = [NSNumber numberWithInt:10000]; // Connect to the SSH server. // The standard SSH port = 22 // The hostname may be a hostname or IP address. NSString *hostname = @"sftp.example.com"; int port = 22; BOOL success = [sftp Connect: hostname port: [NSNumber numberWithInt: port]]; if (success != YES) { NSLog(@"%@",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" password: @"myPassword"]; if (success != YES) { NSLog(@"%@",sftp.LastErrorText); return; } // After authenticating, the SFTP subsystem must be initialized: success = [sftp InitializeSftp]; if (success != YES) { NSLog(@"%@",sftp.LastErrorText); return; } // Assuming we know the file size won't be too large, we get the size as a 32-bit integer. // For SFTP, the remote file path is always either a path relative to the HOME directory of the user account, or an absolute path on the server. BOOL bFollowLinks = YES; BOOL bIsHandle = NO; int fileSize = [[sftp GetFileSize64: @"someDir/someFile.dat" bFollowLinks: bFollowLinks bIsHandle: bIsHandle] longLongValue]; if (fileSize < 0) { NSLog(@"%@",sftp.LastErrorText); return; } NSLog(@"%@%d",@"file size = ",fileSize); // If the file size might be too large for a 32-bit signed integer, then get the size as a decimal string. // You can convert the string to a 64-bit integer in your programming language. NSString *fileSizeStr = [sftp GetFileSizeStr: @"someDir/someFile.dat" bFollowLinks: bFollowLinks bIsHandle: bIsHandle]; if (sftp.LastMethodSuccess == NO) { NSLog(@"%@",sftp.LastErrorText); return; } NSLog(@"%@%@",@"file size = ",fileSizeStr); // You can alternatively get the size with an open file handle. NSString *handle = [sftp OpenFile: @"someDir/someFile.dat" access: @"readOnly" createDisp: @"openExisting"]; if (sftp.LastMethodSuccess != YES) { NSLog(@"%@",sftp.LastErrorText); return; } // Get the size using the handle. bIsHandle = YES; fileSize = [[sftp GetFileSize64: @"someDir/someFile.dat" bFollowLinks: bFollowLinks bIsHandle: bIsHandle] longLongValue]; if (fileSize < 0) { NSLog(@"%@",sftp.LastErrorText); return; } NSLog(@"%@%d",@"file size = ",fileSize); // ----------------------------------------------------------------------------- // Don't forget to close the file handle. // Otherwise open handles will accumulate on the server until eventually a limit // is reached and the server will fail on a call to OpenFile. // ----------------------------------------------------------------------------- // Close the file. success = [sftp CloseHandle: handle]; if (success != YES) { NSLog(@"%@",sftp.LastErrorText); return; } |
© 2000-2024 Chilkat Software, Inc. All Rights Reserved.