ImageVerifierCode 换一换
格式:DOCX , 页数:7 ,大小:18.21KB ,
资源ID:5121959      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/5121959.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(基于vb环境WINDOWS API的ftp上传下载服务的实现.docx)为本站会员(b****4)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

基于vb环境WINDOWS API的ftp上传下载服务的实现.docx

1、基于vb环境WINDOWS API的ftp上传下载服务的实现基于vb的ftp上传下载服务的实现Option ExplicitPublic Declare Function InternetOpen Lib wininet.dll Alias InternetOpenA _(ByVal sAgent As String, ByVal LAccessType As Long, ByVal sProxyName As String, _ByVal SProxyBypass As String, ByVal lFlags As Long) As LongPublic Declare Function

2、InternetConnect Lib wininet.dll Alias InternetConnectA _(ByVal hInternetSession As Long, ByVal sServerName As String, _ByVal nServerPort As Integer, ByVal sUsername As String, _ByVal sPassword As String, ByVal lService As Long, _ByVal lFlags As Long, ByVal lContext As Long) As LongPublic Declare Fun

3、ction FtpGetFile Lib wininet.dll Alias FtpGetFileA _(ByVal hFtpSession As Long, ByVal lpszRemoteFile As String, _ByVal lpszNewFile As String, ByVal fFailIfExists As Boolean, _ByVal dwFlagsAndAttributes As Long, ByVal dwFlags As Long, _ByVal dwContext As Long) As BooleanPublic Declare Function FtpPut

4、File Lib wininet.dll Alias FtpPutFileA _(ByVal hFtpSession As Long, ByVal lpszLocalFile As String, _ByVal lpszRemoteFile As String, ByVal dwFlags As Long, _ByVal dwContext As Long) As BooleanPublic Declare Function FtpDeleteFile Lib wininet.dll Alias FtpDeleteFileA _ (ByVal hFtpSession As Long, ByVa

5、l lpszFileName As String) As Boolean Public Declare Function FtpRenameFile Lib wininet.dll Alias FtpRenameFileA _ (ByVal hFtpSession As Long, ByVal lpszExsiting As String, ByVal lpszNew As String) As Boolean Public Declare Function InternetCloseHandle Lib wininet.dll (ByVal hInet As Long) As Integer

6、Public Declare Function FtpFindFirstFile Lib wininet.dll Alias FtpFindFirstFileA _ (ByVal hFtpSession As Long, ByVal lpszSearchFile As String, _ lpFindFileData As WIN32_FIND_DATA, ByVal dwFlags As Long, _ ByVal dwContent As Long) As Long Public Declare Function InternetFindNextFile Lib wininet.dll A

7、lias InternetFindNextFileA _(ByVal hFind As Long, lpvFndData As WIN32_FIND_DATA) As LongPublic Type FILETIME dwLowDateTime As Long dwHighDateTime As LongEnd TypePublic Type WIN32_FIND_DATA dwFilAttributes As Long ftCreationTime As FILETIME ftLastAccessTime As FILETIME ftLastWriteTime As FILETIME nFi

8、leSizeHigh As Long nFileSizeLow As Long dwReserved0 As Long dwReserved1 As Long cFileName As String * 260 cAlternate As String * 14End TypePublic Declare Function GetOpenFileName Lib comdlg32.dll Alias _ GetOpenFileNameA (pOpenfilename As OPENFILENAME) As LongType OPENFILENAME lStructSize As Long hw

9、ndOwner As Long hInstance As Long lpstrFilter As String lpstrCustomFilter As String nMaxCustFilter As Long nFilterIndex As Long lpstrFile As String nMaxFile As Long lpstrFileTitle As String nMaxFileTitle As Long lpstrInitialDir As String lpstrTitle As String flags As Long nFileOffset As Integer nFil

10、eExtension As Integer lpstrDefExt As String lCustData As Long lpfnHook As Long lpTemplateName As StringEnd TypePrivate Sub Command1_Click()lnginet = InternetOpen(vbNullString, INTERNET_OPEN_TYPE_PRECONFIG, _ vbNullString, vbNullString, 0&)If lnginet Then lnginetconn = InternetConnect(lnginet, ip地址,

11、0, _ 用户名, 密码, 1, 0, 0) If lnginetconn Then blnRC = FtpGetFile(lnginetconn, website/address.asp, c:address.asp, 0, 0, 1, 0) If blnRC Then MsgBox download ok! End If InternetCloseHandle lnginetconn InternetCloseHandle lnginet MsgBox close ok! Else MsgBox cant connect End IfElse MsgBox ftp wrongEnd IfE

12、nd SubPrivate Sub Command2_Click()Dim pData As WIN32_FIND_DATADim lngHINet As LongDim intError As IntegerDim strTemp As StringDim blnRC As BooleanpData.cFileName = String(260, 0)lnginet = InternetOpen(vbNullString, INTERNET_OPEN_TYPE_PRECONFIG, _ vbNullString, vbNullString, 0&)If lnginet Then lngine

13、tconn = InternetConnect(lnginet, IP地址, 0, _ 用户名, 密码, 1, 0, 0) If lnginetconn Then lngHINet = FtpFindFirstFile(lnginetconn, *.*, pData, 0, 0) strTemp = Left(pData.cFileName, InStr(1, pData.cFileName, String(1, 0), vbBinaryCompare) - 1) Do pData.cFileName = String(260, 0) blnRC = InternetFindNextFile(

14、lngHINet, pData) If Not blnRC Then Exit Do Else strTemp = Left(pData.cFileName, InStr(1, pData.cFileName, String(1, 0), vbBinaryCompare) - 1) End If Loop Text1.Text = strTemp End If End If InternetCloseHandle lngHINet InternetCloseHandle lnginetconn InternetCloseHandle lnginetEnd Sub在FTP中,Put、Rename

15、、 Delete是怎样的?这些函数也相当简单。首先来看看Put 函数。 基本步骤是: 1、调用InternetOpen函数设置环境。 2、调用InternetConnect 函数连接主机。 3、调用FtpPutFile 函数得到文件。 4、用InternetCloseHandle 函数关闭第1、2步的句柄。 当使用FtpGetFile 时与上面的步骤看起来完全一样。事实上唯一的区别是在第3步中调用了FtpPutFile 。VB特定调用这一函数的声明是: Private Declare Function FtpPutFile Lib wininet.dll Alias FtpPutFileA _

16、 (ByVal hFtpSession As Long, ByVal lpszLocalFile As String, _ ByVal lpszRemoteFile As String, ByVal dwFlags As Long, _ ByVal dwContext As Long) As Boolean 第一个参数hFtpSession 是InternetConnect 调用返回的句柄值。 lpszNewFile 和lpszRemoteFile 分别是本地机上的文件名和将在远程主机上创建的文件名。 参数dwFlags 指定为1时,用ASCII 传输文件(A类传输方法),指定为2是用二进制传

17、输文件(1类传输方法)。由于DIRMAP.TXT 是ASCII 文本文件,我们传递值1。 最后,当使用回叫信号时,lContext 用来识别应用程序前后关系。因为在我们的例子中不使用回叫信号,所以这个值为0。 以下是得到DIRMAP.TXT文件并将其存在 C:DIRMAP.TXT的调用。 blnRC = FtpPutFile(lngINetConn, 揷:dirmap.txt? 揹irmap.txt? 1, 0) 如果函数调用成功,blnRC为 True, 反之为False。 你可以看到,把文件放到FTP服务器上与从FTP服务器上得到文件一样简单。有一点要注意,匿名用户无权在FTP服务器上创建

18、文件。所以要确定用来与FTP服务器连接的用户帐号要有创建文件的权限。不然的话,FtpPutFile函数调用就会返回False,说明Put 失败了。 现在我们用FtpDeleteFile 函数删除一个名为Test.txt的文件。同样只有第三步中的函数调用发生了改变。VB特定调用这一函数的声明是: Private Declare Function FtpDeleteFile Lib wininet.dll Alias FtpDeleteFileA _ (ByVal hFtpSession As Long, ByVal lpszFileName As String) As Boolean 第一个参数

19、hFtpSession 是InternetConnect 调用返回的句柄值。 lpszFileName 是FTP服务器上要删除的文件。 下面是在FTP服务器上删除TEST.TXT 文件的调用: blnRC = FtpDeleteFile(lngINetConn, Test.txt) 如果函数调用成功,blnRC为 True, 反之为False。 要注意什么? 几乎所有的FTP函数都一样:设置环境,连接主机,执行FTP任务,清除。但是也有例外。如何得到一个路径列表或者得到文件之前读文件的内容?这些类型的FTP任务只是有一点点复杂。首先看看路径列表问题。 列举路径的基本步骤也是一样的。首先还是要设

20、置环境,连接FTP服务器。结束之后还是要清楚连接和句柄。为了实际得到路径内容,需要使用两个新函数:FtpFindFirstFile 和InternetFindNextFile。VB特定调用这一函数的声明是: Private Declare Function FtpFindFirstFile Lib wininet.dll Alias FtpFindFirstFileA _ (ByVal hFtpSession As Long, ByVal lpszSearchFile As String, _ lpFindFileData As WIN32_FIND_DATA, ByVal dwFlags A

21、s Long, _ ByVal dwContent As Long) As Long 第一个参数hFtpSession 是InternetConnect 调用返回的句柄值。 lpszSearchFile 是FTP服务器上的路径或文件名。如果你指定了一个空字符,就使用当前路径。另外还可以指定通配符。例如,要列出以ms开始的根目录下的路径内容,就使用ms*? 。 lpFindFileData 与我们使用的其它参数有一点不同。数据类型WIN32_FIND_DATA 是用户定义类型,保存关于路径下的文件的信息。类型看起来是这样的: Private Type WIN32_FIND_DATA dwFile

22、Attributes As Long ftCreationTime As FILETIME ftLastAccessTime As FILETIME ftLastWriteTime As FILETIME nFileSizeHigh As Long nFileSizeLow As Long dwReserved0 As Long dwReserved1 As Long cFileName As String * MAX_PATH cAlternate As String * 14 End Type 注意,有许多参数有不同的用户定义数据类型:FILETIME。下面是它们的类型定义: Privat

23、e Type FILETIME dwLowDateTime As Long dwHighDateTime As Long End Type 在我们的例子中,只使用dwFileAttributes的内容,其中包含文件的属性,还有cFileName,其中包含文件名。 最后,我们的例子不使用dwFlags 和 dsContext ,所以每个都传递0。 下面在当前路径下开始路径列举的调用: lngHINet = FtpFindFirstFile(lngINetConn, *.*, pData, 0, 0) 如果函数失败,就返回0。否则,用来继续进行路径列举的lngHInet 是一个有效句柄。另外,第一

24、个文件名和属性储存在pData 参数中。 一旦调用了FtpFindFirstFile 并返回一个有效句柄,我们要调用InternetFindNextFile 函数除非它返回错误值18表示没有可以列举的文件。对InternetFindNextFile的VB特定声明是: Private Declare Function InternetFindNextFile Lib wininet.dll Alias InternetFindNextFileA _ (ByVal hFind As Long, lpvFindData As WIN32_FIND_DATA) As Long 第一个参数,hFind

25、是 FtpFindFirstFile 调用所返回的句柄。 lpvFindData 是同样的用户定义类型,用在FtpFindFirstFile 调用中存储文件信息。 下面是在路径中得到下一个文件的调用: blnRC = InternetFindNextFile(lngHINet, pData) 如果调用成功,blnRC 返回 True,否则 blnRC 为False。Err对象的LastDllError返回18表明再没有文件存在了。 现在再回来看看基本的四步:第1步和第2步(设置环境和连接服务器)应该已经完成。以下列出的第三步。最后一步,第四步,就清除环境和连接句柄,跟前面一样: Dim pDa

26、ta As WIN32_FIND_DATA Dim lngHINet As Long Dim intError As Integer Dim strTemp As String Dim blnRC As Boolean init the filename buffer pData.cFileName = String(260, 0) get the first file in the directory. lngHINet = FtpFindFirstFile(mlngINetConn, *.*, pData, 0, 0) howd we do? If lngHINet = 0 Then ge

27、t the error from the findfirst call intError = Err.LastDllError is the directory empty? If intError ERROR_NO_MORE_FILES Then whoa.a real error Error handler? End If Else we got some dir info. get the name strTemp = Left(pData.cFileName, InStr(1, pData.cFileName, String(1, 0), vbBinaryCompare) - 1) D

28、o init the filename buffer pData.cFileName = String(260, 0) get the next item blnRC = InternetFindNextFile(lngHINet, pData) howd we do? If Not blnRC Then get the error from the findnext call intError = Err.LastDllError no more items If intError 18 Then whoa.a real error 卐rror handler? Exit Do Else no more items. Exit Do End If Else get the last item returned strTemp = Left(pData.cFileName, InStr(1, pData.cFileName, String(1, 0), vbBinaryCompare) - 1) 卻tore the file info someplace? End If Loop close the handle for the dir listing InternetCloseHandle lngHINet End If

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1