设为首页 收藏本站
查看: 728|回复: 0

用VB6写简单的FTP上传程序

[复制链接]
发表于 2015-5-28 11:55:57 | 显示全部楼层 |阅读模式
  最近在想用VB写个FTP上传 的ACTIVEX控件,于是现学现用,网上找了很多资料,其中有一篇VB实现FTP上传的文章讲了一个利用Inet实现的方法和示例,于是自己也参照做了一个,功能还不完善,只能实现基本的上传能力。
  首先,在VB工具栏中添加部件Microsoft Internet Transfer Control 6.0 ,之后工具箱会多一个Inet的控件。
  拖放该控件到窗体上,设置控件中的属性
  protocol : 2-icFTP
RemoteHost : 你的FTP服务IP或域名
RemotePort : 你的FTP端口
URL : 你的FTPURL地址
UserName和Password 这两个就不用说了
  当然,也可以在运行时绑定属性。
  本例中还需要拖放一个文本筐(txtData)和一个按钮(Command1)
  窗体代码部分如下:

Private Sub Command1_Click()
     
        
        Dim isRight As Boolean '定义一个BOOLEAN变量,用于判断是否仍然在执行上传
               
        Dim filestr As String '定义一个字符串变量,用于存储本地文件的路径和文件名,并在后面赋值,当然,正式使用的时候这里是由用户选择文件的路径
        
        filestr = "d:/ctrpatch1229-0829.exe"
               
        '调用Inet的execute方法上传文件,第一参数是FTP URL地址,第2个参数是传递参数,字符串型,分为3个部分: 方法+本地文件+上传后文件名 ,FTP上传使用 PUT 命令
        Inet1.Execute "ftp://192.168.1.17", "PUT " & filestr & " uploadedfilename.exe" 'put,本地文件路径,上传后的文件名称之间一定要有空格隔开
               
        isRight = Inet1.StillExecuting '获取当前是否仍然在执行命令
        
        '循环检查是否仍然在命令执行,如果仍然还在执行命令,那么将控制权交给系统,这样系统可以分配空闲的处理时间来执行命令
        Do While isRight
        
           isRight = Inet1.StillExecuting
           DoEvents
        
        Loop



End Sub


'在调用Inet的Execute方法时会触发该时间,该事件传递一个参数State来返回当前执行状态
'返回的状态值如下:
'0            未报告状态icHostResolvingHost
'1            控件正在寻找指定主机的IP地址icHostResolved
'2            控件已成功找到指定主机的IP地址icConnecting
'3            控件正在与指定主机进行连接icConnected
'4            控件已成功与指定主机连接icRequesting
'5            控件正在向主机发出请求icRequestSent
'6            控件已成功向主机发出请求icReceivingResponse
'7            控件正在从主机接收反馈信息icResponseReceived
'8            控件已成功从主机接受反馈信息icDisconnecting
'9            控件正在与主机断开icDisconnected
'10           控件已与主机断开icError
'11           在与主机通信的过程中发生了错误icResponseComp leted
'12           请求结束且数据已经接收到

Private Sub Inet1_StateChanged(ByVal State As Integer)

      '获取并显示一下当前的执行状态,方便测试
      txtData.Text = txtData.Text + CStr(State)

      '检查当前返回的状态值
      Select Case State
      
      '如果是12,说明执行完成
      Case 12
      
      '以下=号中间的代码我暂时还不知道具体有什么在作用
      '==============================================
      Dim vtData     As Variant     '   Data   variable.
      Dim strData     As String:     strData = ""
      Dim bDone     As Boolean:     bDone = False
      '   Get   first   chunk.
      vtData = Inet1.GetChunk(1024, icString)
      Do While Not bDone
      strData = Data & vtData
      '   Get   next   chunk.
      vtData = Inet1.GetChunk(1024, icString)
      If Len(vtData) = 0 Then
           bDone = True
      End If
      Loop
      txtData.Text = strData

      '===============================================
      
      txtData.Text = "上传完成"
      
      End Select

   
End Sub



很简单,但是有人评论说Inet不好,用Winsock好些,但是我还不太了解,目前还不知道两者间的区别和优略,继续研究……

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-71484-1-1.html 上篇帖子: IIS配置FTP的两三事 下篇帖子: Red Hat Enterprise Linux 5下配置FTP服务
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表