This is the main interface class of the WinSCP assembly.
It represents a session and provides methods for manipulating remote files over SFTP, FTP, WebDAV, S3 or SCP session.
|string AdditionalExecutableArguments||Additional command-line arguments to be passed to
|string DebugLogLevel||Logging level of debug log to. The default value is
|string DebugLogPath||Path to store assembly debug log to. Default
|Deprecated. Do not use. Use
|Deprecated. Disables test that WinSCP executables have the same product version as this assembly.1 The property has to be set before calling
|string ExecutablePath||Path to
|string ExecutableProcessUserName||If the .NET process is running in an impersonated environment, you need to provide credentials of the impersonated account, so that the
|string HomePath||Path to a remote home directory. The property can be read only after calling
|Deprecated. Do not use. Use
|string SessionLogPath||Path to store session log file to. Default
|bool Opened||Is session opened yet?
|StringCollection Output||Output of WinSCP console session. See also
|TimeSpan ReconnectTime||Sets time limit in seconds to try reconnecting broken sessions. Default is 120 seconds. Use
|int ReconnectTimeInMilliseconds||Alternative to
|TimeSpan Timeout||Maximal interval between two consecutive outputs from WinSCP console session, before
|Abort||Forcefully aborts session.|
|AddRawConfiguration||Allows setting any configuration settings using raw format as in an INI file.|
|CalculateFileChecksum||Calculates a checksum of a remote file.|
|Deprecated. Combines strings into a remote path.|
|CompareDirectories||Compares directories, the same way
|CreateDirectory||Creates remote directory.|
|Dispose||Closes session and disposes object.|
|DuplicateFile||Duplicates remote file to another remote directory.|
|Deprecated. Converts special characters in file path to make it unambiguous file mask/wildcard.|
|EnumerateRemoteFiles||Recursively enumerates remote files.|
|ExecuteCommand||Executes command on the remote server.|
|FileExists||Checks for existence of remote file.|
|GetFileInfo||Retrieves information about remote file.|
|ListDirectory||Lists remote directory.|
|MoveFile||Moves remote file to another remote directory and/or renames remote file.|
|Open||Opens the session.|
|RemoveFiles||Removes remote files.|
|ScanFingerprint||Scans a fingerprint of SSH server public key or FTPS/WebDAVS TLS certificate.|
|SynchronizeDirectories||Synchronizes local directory with remote directory.|
|Deprecated. Generates a remote path equivalent of a local path, given root paths.|
|Deprecated. Generates a local path equivalent of a remote path, given root paths.|
|Failed||Occurs on error during any operation.|
|FileTransferProgress||Occurs regularly during file transfer to report transfer progress.|
|FileTransferred||Occurs when file is transferred.|
|OutputDataReceived||Occurs on output from WinSCP console session.|
|QueryReceived||Occurs when a decision is needed (i.e. typically on any non-fatal error).|
To use the class:
- Create an instance of
SessionOptionsand fill in all needed information to connect and authenticate the session automatically;
- Create an instance of
- Usually all properties of
Sessioncan be left with their default values;
- Assign event handlers, if continuous monitoring of operation is required;
Openmethod passing instance of
- Use any file manipulation methods you need, such as
The class is locked against concurrent accesses from multiple threads. Though you can use several instances of the class in parallel, even from different threads.
Methods from both classes throw
SessionLocalException on error in communication with WinSCP console session.
Methods for atomic operations throw
SessionRemoteException on error originating from WinSCP console session (referred to as “failure” below).
Methods for batch operations returns an instance of descendant of
OperationResultBase class (such as
SynchronizationResult). Such result class stores list of operations performed (e.g.
TransferOperationResult.Uploads), and list of failures (
Every structure representing operation performed may refer (e.g. in
TransferEventArgs.Error) to one of the failures, if the failure can be explicitly associated with the operation. So often the same failure (represented by
SessionRemoteException) will be referenced twice in the results.
But there can be failures that cannot be explicitly associated with any operation represented in results. An example is an error when listing contents of remote directory to determine list of files to downloads. The listing is not represented in the results, so the failure will be included only in a generic list of failures.
If you do not want to check the list of failures after every batch operation method call, you can use method
OperationResultBase.Check to throw the first failure in the list, if any failure occurred:
// Throw, if upload fails session.PutFiles(localPath, remotePath).Check();
Also for all failures the
Session.Failed event is raised.
The batch operation though typically aborts on the first major failure. To customize error processing, handle
Session.QueryReceived. For an example, see Recursively download directory tree with custom error handling.
For example how to check and print errors, but continue, see real-life example Search recursively for text in remote directory / Grep files over SFTP/FTP protocol.
- Note, even if you set this property, you need to use the assembly with compatible WinSCP executable only. Otherwise the behavior is unpredictable. In general, it is not recommended to use this. In neither case will you be able to use the assembly with WinSCP 5.0.4 or older.Back