最新有一个需求,需要在ssis中调用sftp下载文件,由于服务器上只有framework2.0,并且需要用sqlserver代理调用作业,限制了很多。

首先用的是脚本任务,进程调用winscp.com执行,这中间碰见一个问题,不能控制什么时间winscp执行完成,导致作业卡死,第一种尝试方式失败。

接着用脚本任务,调用winscp.dll类进行操作,这中方式用c#代码可以实现,但是用脚本任务时间,添加winscp.dll引用,编译没有问题,执行时间报“未能找到winscp.dll”(怀疑是动态调用dll的原因,暂未解决)第二种尝试失败。

重点来了,最后用VBScript调用winscp的方式,因为这种最后成功了,哈哈,接下来说步骤

winscp官网(https://winscp.net/eng/docs/lang:chs)给的有文档,大家可以去看下,我这英语三级半的水平用翻译都整出来了。

服务器上是framework2.0,官网给的说明支持2.0,但是最新的源码里添加失败,就考虑换老版的dll(https://sourceforge.net/projects/winscp/files/WinSCP/),我用的5.9版本的,

用命令注册(注册时间在dll文件夹中打开命令)

C:\Windows\Microsoft.NET\Framework\v2.0.50727\RegAsm.exe WinSCPnet.dll /codebase /tlb:WinSCPnet32.tlb
C:\Windows\Microsoft.NET\Framework64\v2.0.50727\RegAsm.exe WinSCPnet.dll /codebase /tlb:WinSCPnet64.tlb

然后在ssis中添加ActiveX脚本任务,选择VBScript语言

Function Main()
' Setup session options
Dim sessionOptions
Set sessionOptions = CreateObject("WinSCP.SessionOptions")
With sessionOptions
.Protocol = Protocol_Sftp
.HostName = "127.0.0.1"
.UserName = "mysftp"
.Password = "password"
.SshHostKeyFingerprint = "xxxx"(这个地方需要用winscp软件先连接sftp服务器,然后在站点右键----generate session URL/Code中可以找到)
End With

Dim session
Set session = CreateObject("WinSCP.Session")

' Connect
session.Open sessionOptions

' Download files
Dim transferOptions
Set transferOptions = CreateObject("WinSCP.TransferOptions")
transferOptions.TransferMode = TransferMode_Binary

Dim transferResult

if session.FileExists("/") then
Set transferResult = session.GetFiles("/*", "d:\import\", False, transferOptions)
end if
' Throw on any error
transferResult.Check

' Print results
Dim transfer
For Each transfer In transferResult.Transfers
Echo "Download of " & transfer.FileName & " succeeded"
Next

' Disconnect, clean up
session.Dispose

End Function

到此通过sftp获取文件成功。

-----------------------------再更新记录一点

SshHostKeyFingerprint=“ssh-ed25519 256 4d:dd:48:af:76:c2:ba:a8:bc:20:f3:28:1d:6a:28:53”;

服务器算法升级时,如果提醒报错,报错信息中会有新的hostKey,在5.9版本中如果用软件生成的代码ssh-ed25519 256 mjXd5ywKQ0jROXgw7mmMqbSOAjTZU4gl0VQDt2DjybY=可能报错,说不符合规则,连接上winscp,在服务器信息/协议信息中可以看到hostkey对应的MD5值,换成MD5值试试。

VBScript调用winscp,实现sftp操作的更多相关文章

  1. WinSCP命令行操作

    WinSCP命令行操作     WinSCP是一个Windows环境下使用SSH的开源图形化SFTP客户端.同时支持SCP协议.它的主要功能就是在本地与远程计算机间安全的复制文件. 直接在cmd下输入 ...

  2. SSIS 通过 WINscp 从SFTP下载文件

    1.通过SSIS的process task调用 winscp :C:\Program Files (x86)\WinSCP\WinSCP.exe /script="C:\SFTPFile\T ...

  3. ASP.NET实现二维码 ASP.Net上传文件 SQL基础语法 C# 动态创建数据库三(MySQL) Net Core 实现谷歌翻译ApI 免费版 C#发布和调试WebService ajax调用WebService实现数据库操作 C# 实体类转json数据过滤掉字段为null的字段

    ASP.NET实现二维码 using System;using System.Collections.Generic;using System.Drawing;using System.Linq;us ...

  4. 读Hadoop3.2源码,深入了解java调用HDFS的常用操作和HDFS原理

    本文将通过一个演示工程来快速上手java调用HDFS的常见操作.接下来以创建文件为例,通过阅读HDFS的源码,一步步展开HDFS相关原理.理论知识的说明. 说明:本文档基于最新版本Hadoop3.2. ...

  5. 转: window中使用PSFTP/WinSCP实现SFTP上传下载

    sftp 服务器:  dbmonitor 1.sftp属于交互式的,所以你得缓存下命令#!/bin/shsftp -o Port=3322 root@172.16.1.21:/opt << ...

  6. vbscript 中对excel常见操作

    vbs 对excel的操作 删除.修改单元格,设置字体.背景色dim oExcel,oWb,oSheet Set oExcel= CreateObject("Excel.Applicatio ...

  7. 使用SSH+SFTP操作终端全解析,告别XShell

    1.前言 在Windows系统下操作远程服务器的方式很多,比如XShell+XFTP组合,亦或是PuTTY+WinSCP组合,但在Mac系统下登陆远程服务器,并没有这些工具供我们使用.相比较而言,在M ...

  8. vbscript调用WMI一键式式发布网站

    作为.net开发,在window环境下,不得不熟悉些脚本语言,来减轻些日常开发中所遇到的一些繁杂的事情,比如自动发布网站,自动发布网站等等. WMI windows管理程序接口,可用各种与语言调用,方 ...

  9. 使用sftp操作文件并添加事务管理

    本文主要针对文件操作的事务管理,即写文件和删除文件并且能保证事务的一致性,可与数据库联合使用,比如需要在服务器存文件,相应的记录存放在数据库,那么数据库的记录和服务器的文件数一定是要一一对应的,该部分 ...

随机推荐

  1. 浏览器开发者工具network详解

    General概诉 请求链接 Request URL: 请求方式 Request Method: 代码状态 Status Code: 远程地址 Remote Address: 引用协议 用于过滤 Re ...

  2. log4j配置获取系统属性及默认值

    一.使用场景 1.因某些原因,我们可能将log4j中的配置变量化,进行动态获取 2.动态获取内容不存在时,我们希望能够赋上通用的值 二.语法 单变量: ${前缀:变量:-默认值} 如: ${sys:i ...

  3. python监控文件实时批量压缩脚本

    # coding:utf-8 from shutil import make_archive import os import time # 指定需要监测的文件夹 image_path = './im ...

  4. redis 五种常见攻击方法

    如果需要大佬写好的脚本,可以直接去github上面搜 参考文章:https://www.cnblogs.com/wineme/articles/11731612.html    https://www ...

  5. SpringBoot执行原理

    目录 [Toc] 一.执行原理: 每个Spring Boot项目都有一个主程序启动类,在主程序启动类中有一个启动项目的main()方法, 在该方法中通过执行SpringApplication.run( ...

  6. 【程序包管理】篇章2:rpm程序包来源合法和完整性验正

    来源合法性验正: 数字签名   私钥签名完整性    哈希 注意: 1.如果是网站下载的程序包的话,没有公钥,就无法进行来源合法性验证,所以最好使用系统自带的rpm程序包或去可靠的网站下载程序包.[如 ...

  7. BF,BM,KMP,就这?

    为保证代码严谨性,文中所有代码均在 leetcode 刷题网站 AC ,大家可以放心食用. 皇上生辰之际,举国同庆,袁记菜馆作为天下第一饭店,所以被选为这次庆典的菜品供应方,这次庆典对于袁记菜馆是一项 ...

  8. How to install android studio on ubuntu14.04

    First: open the web page: https://developer.android.com/studio/index.html download the Android Studi ...

  9. 如何解决Visual Studio 首次调试 docker 的 vs2017u5 exists, deleting Opening stream failed, trying again with proxy settings

    前言 因为之前我电脑安装的是windows10家庭版,然而windows10家庭没有Hyper-v功能. 搜索了几篇windows10家庭版安装docker相关的博客,了解一些前辈们走过的坑. 很多人 ...

  10. java注解学习笔记总结

    注解的理解 ① jdk 5.0 新增的功能 ② Annotation 其实就是代码里的特殊标记, 这些标记可以在编译, 类加载, 运行时被读取, 并执行相应的处理.通过使用 Annotation,程序 ...