1. access https://winscp.net
data:image/s3,"s3://crabby-images/8c7ff/8c7ffb47d92591f7246621b72a9ff72c424c6fa8" alt=""
2. Click! [Installation package]
data:image/s3,"s3://crabby-images/ca29b/ca29b9fd06a166d92685da5f3d74b8df22742225" alt=""
3. You can download setup file
data:image/s3,"s3://crabby-images/dccac/dccacfa1e5308b4c3d24dd057cd50a8b3e96b7f4" alt=""
4. Install
data:image/s3,"s3://crabby-images/fb6b3/fb6b33a2960a4d950e06d5913dd358545dfef483" alt=""
5. Proceed with the installation
data:image/s3,"s3://crabby-images/1f3f3/1f3f384931194d5e182f49d9913d0bb0c9bf9578" alt=""
--------------------------------------------------------------------------------------------------------------------------
.Net assembly
1. You can look "WinSCPnet.dll" after you install WinSCP above.
data:image/s3,"s3://crabby-images/b9c6a/b9c6af25a551460ed9dddbbfc69aeafef399631f" alt=""
2. Run the following code
"C:\Program Files (x86)\Microsoft SDKs\Windows\v7.0A\Bin\gacutil.exe" /i WinSCPnet.dll
data:image/s3,"s3://crabby-images/c1e64/c1e64dbfa87a35a47d7b67b4f88491b753b4d4e1" alt=""
--------------------------------------------------------------------------------------------------------------------------
Development SSIS
1. You can look "WinSCPnet.dll" after you install WinSCP above.
data:image/s3,"s3://crabby-images/daaac/daaacc950dd938d2aa84b01c27621c0442dd9083" alt=""
2. Click "Variables" on new small window after mouse right click at anywhere
data:image/s3,"s3://crabby-images/d04bc/d04bc0e10c0af3428e9128ac1c403234b58b4e42" alt=""
3. Make Variables value by your SFTP information
data:image/s3,"s3://crabby-images/b5c7a/b5c7a9fbac96237071cf04d0ccde81c1c98d3efe" alt=""
4. Click small icon after double click [Script Task Editor]
And, Select Variables that you made previous
data:image/s3,"s3://crabby-images/bc48d/bc48d056bb822f8ae1568891224097c524c47475" alt=""
5. Click [Edit Script]
data:image/s3,"s3://crabby-images/8b9e6/8b9e6306f5bada42e957e1c20be57f11fe711344" alt=""
6. Add WinSCPnet.dll into "Reference" (The dll file location = C:\Program Files (x86)\WinSCP )
data:image/s3,"s3://crabby-images/48c5d/48c5dd1c4a609cbb621b573cb6376d5ffb9232b6" alt=""
7. Add below code into Main() method.
// TODO: Add your code here
string winscpPath = Dts.Variables["winSCPPath"].Value.ToString();
string username = Dts.Variables["User::UserName"].Value.ToString();
string password = Dts.Variables["User::Password"].Value.ToString();
string hostName = Dts.Variables["User::HostName"].Value.ToString();
string localPath = Dts.Variables["User::LocalPath"].Value.ToString();
string remoteFTPDirectory = Dts.Variables["User::FTPDirectory"].Value.ToString();
string sshKey = Dts.Variables["SshHostKeyFingerprint"].Value.ToString();
Boolean winSCPLog = (Boolean)Dts.Variables["User::winSCPLog"].Value;
string winSCPLogPath = Dts.Variables["User::winSCPLogPath"].Value.ToString();
SessionOptions sessionOptions = new SessionOptions
{
Protocol =
Protocol.Sftp,
FtpMode = WinSCP.
FtpMode.Active,
FtpSecure =
FtpSecure.None,
HostName = hostName,
UserName = username,
Password = password,
SshHostKeyFingerprint = sshKey,
TimeoutInMilliseconds = 90000
};
try
{
using (Session session = new Session())
{
// WinSCP .NET assembly must be in GAC to be used with SSIS,
// set path to WinSCP.exe explicitly, if using non-default path.
session.ExecutablePath = winscpPath;
session.DisableVersionCheck =
true;
if (winSCPLog)
{
session.SessionLogPath = @winSCPLogPath +
@"WinscpSessionLog.txt";
session.DebugLogPath = @winSCPLogPath +
@"WinscpDebugLog.txt";
}
// Connect
sessionOptions.GiveUpSecurityAndAcceptAnySshHostKey =
true;
session.Open(sessionOptions);
TransferOptions transferOptions = new TransferOptions();
transferOptions.TransferMode =
TransferMode.Binary;
try
{
session.GetFiles(remoteFTPDirectory, localPath,
false, transferOptions);
}
catch (Exception e)
{
Dts.Events.FireError(0,
null,
string.Format("Error when using WinSCP to download file: {0}", e), null, 0);
Dts.TaskResult = (
int)DTSExecResult.Failure;
}
}
Dts.TaskResult = (
int)ScriptResults.Success;
}
catch (Exception ex)
{
Dts.Events.FireError(0,
null,
string.Format("Error when using WinSCP to download file: {0}", ex), null, 0);
Dts.TaskResult = (
int)DTSExecResult.Failure;
}
data:image/s3,"s3://crabby-images/8321b/8321bb33f3c5a9a5f440f9572a7a646b0ab47eb4" alt=""