InternetReadFile如何正确读取二进制文件

 
 
手上的一个VB项目(过程中发现,.Net果然是好啊),需要在一个ActiveX中实现HTTP下载功能,我是采用InternetreadFile这个API来实现,一开始的代码我是这么写的
 
None.gif Function  Gethttpdownload(sUrl  As   String As  boolen
None.gif 
None.gif
Dim  s  As   String
None.gif
Dim  hOpen  As   Long
None.gif
Dim  hOpenUrl  As   Long
None.gif
Dim  bDoLoop  As   Boolean
None.gif
Dim  bRet  As   Boolean
None.gif
Dim  sReadBuffer  As   String   *   2048
None.gif
Dim  lNumberOfBytesRead  As   Long
None.gifhOpen 
=  InternetOpen(scUserAgent, INTERNET_OPEN_TYPE_PRECONFIG, vbNullString, vbNullString,  0 )
None.gifhOpenUrl 
=  InternetOpenUrl(hOpen, sUrl, vbNullString,  0 , INTERNET_FLAG_RELOAD,  0 )
None.gif bDoLoop 
=   True
None.gif 
Do   While  bDoLoop
None.gif  sReadBuffer 
=  vbNullString
None.gif  bRet 
=  InternetReadFile(hOpenUrl, sReadBuffer,  Len (sReadBuffer), lNumberOfBytesRead)
None.gif  s 
=  s  &   Left $(sReadBuffer, lNumberOfBytesRead)
None.gif  
If   Not   CBool (lNumberOfBytesRead)  Then  bDoLoop  =   False
None.gif  
Loop
None.gifFileName 
=   " E:\BitSpirit\Torrent\121212.torrent"
None.gif
F1  =  FreeFile
None.gifOpen FileName 
For  Binary  As  F1
None.gifPut F1, , s
None.gifClose F1
None.gif 
If  hOpen  <>   0   Then  InternetCloseHandle (hOpen)
None.gif Gethttpdownload 
=   true
None.gif 
End Function
None.gif
 
上面方法,用来获取服务器上的文本类型的文件一点问题,都没有,但是用来下载二进制文件的时候 就出现问题了,里面的数据怎么也不对,研究了下载下来的文件后发现,问题外话应该是在接收数据的变量是个STRING的定长字符串上。但是在网上查了好久,甚至M$ MSDN上的一个用VB来实现下载的程也是用 string类型来接收数据的而且网上的代码写法,基本上也都是这个样,好来才好现,都是从MSDN上的哪个例程上演变过来的.
       我想如果能用一个byte数组来代替定长字符串,哪可能就没有问题了,但是查看了一个VB 对Internetreadfile的申明
Public Declare Function InternetReadFile Lib "wininet.dll" (ByVal hFile As Long, ByVal sBuffer As String, ByVal lNumBytesToRead As Long, lNumberOfBytesRead As Long) As Integer
发现其定义 ByVal sBuffer As String 看来只能用String了,在网上查找过程中,发现人家用VC写的程序中这人参数可以是其它的,所以查看了一下Internetreadfile的原型。发现的确可以, 所以我把internetreadfile的定义修改了一下,为了通用,我为新的internetreadfile定义了一个别名。Internetreadfilebyte申明如下:
Public Declare Function InternetReadFileByte Lib "wininet.dll" Alias "InternetReadFile" (ByVal hFile As Long, ByRef sBuffer As Byte, ByVal lNumBytesToRead As Long, lNumberOfBytesRead As Long) As Integer
试了一下的确可以,重新修改函数,(在这过程中发现,如果要取到正确数据,还必须取得文件大小。所以增加了HttpQueryInfo的定义)最后完整的函数
None.gif Function  FileDownload(sUrl  As  Variant)  As   Boolean
None.gif        
Dim  b( 99 As   Byte
None.gif        
Dim  EndByte()  As   Byte
None.gif        
Dim  s  As   String
None.gif        
Dim  hOpen  As   Long
None.gif        
Dim  hOpenUrl  As   Long
None.gif        
Dim  bDoLoop  As   Boolean
None.gif        
Dim  bRet  As   Boolean
None.gif        
Dim  bbuffer  As   Byte
None.gif        
Dim  sReadBuffer  As   String
None.gif        
Dim  FileName  As   String
None.gif        
Dim  lNumberOfBytesRead  As   Long
None.gif        
Dim  F1  As   Integer
None.gif        
Dim  strsize  As   String
None.gif        
Dim  size  As   Long
None.gif        strsize 
=   String $( 1024 "   " )
None.gif 
None.gif        F1 
=  FreeFile
None.gif        stTotal 
=  vbNullString
None.gif        FileName 
=   " E:\BitSpirit\Torrent\121212.torrent"
None.gif
        Open FileName  For  Binary  As  F1
None.gif        hOpen 
=  InternetOpen(scUserAgent, INTERNET_OPEN_TYPE_PRECONFIG, vbNullString, vbNullString,  0 )
None.gif        hOpenUrl 
=  InternetOpenUrl(hOpen, sUrl, vbNullString,  0 , INTERNET_FLAG_RELOAD,  0 )
None.gif        bDoLoop 
=   True
None.gif        HttpQueryInfo hOpenUrl, HTTP_QUERY_CONTENT_LENGTH 
Or  HTTP_QUERY_FLAG_NUMBER, ByVal strsize,  Len (strsize),  0
None.gif        size 
=   CLng ( Trim (strsize))
None.gif         
For  j  =   1   To  size  \   100
None.gif          bDoLoop 
=  InternetReadFileByte(hOpenUrl, b( 0 ),  100 , lNumberOfBytesRead)
None.gif 
None.gif          Put F1, , b
None.gif          
If   Not   CBool (lNumberOfBytesRead)  Then   Exit   For
None.gif         
Next
None.gif        
If  size  Mod   100   <>   0   Then
None.gif        tmp 
=  (size  Mod   100 -   1
None.gif        
ReDim  EndByte(tmp)
None.gif          bDoLoop 
=  InternetReadFileByte(hOpenUrl, EndByte( 0 ), tmp  +   1 , lNumberOfBytesRead)
None.gif          Put F1, , EndByte
None.gif        
End   If
None.gif 
None.gif         
If  hOpenUrl  <>   0   Then  InternetCloseHandle (hOpenUrl)
None.gif         
If  hOpen  <>   0   Then  InternetCloseHandle (hOpen)
None.gif 
None.gif        Close #
1
None.gif        FileDownload 
=   True
None.gif
End Function
None.gif
测试了一下,完全成功:)
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值