请问如何用'net/http'库下载文件(并且能知道网络文件的字节数和已经下载的字节数)
[code="ruby"]
require 'net/http'
begin
info = Net::HTTP.get_response(URI.parse("http://www.zf08.net/home/mxxyy/UpFile/Data.doc")).body
rescue
puts "下载补丁失败,请检测网络连接和防火墙。"
end
if info != nil
file = File.new("Data.doc","wb")
file.write info
file.close
end
[/code]
上面这段是我用来下载文件的代码。可是,由于所下载的网络文件比较大,运行之后基本上就卡住了。于是,我想知道怎么获取已经下载的网络文件字节数和网络文件的字节数。这样的话就可以做一个进度条,最起码可以知道目前的下载状况。(最好还能知道下载的速度)
所以,请问如何用'net/http'库下载文件(并且能知道网络文件的字节数和已经下载的字节数)。
求一个比较好的下载文件的范例。
1.如果是你自己的文件你可以使用head方法先在返回的http header里获取长度,但是如果是别人服务器上的文件head方法是不会给你返回content-length的。
2.太大可以在request 里加入accept-encoding gzip选项,下载回来再解压。
3.看看迅雷怎么搞的..
[code="c"]
(Request-Line):GET /home/mxxyy/UpFile/Data.doc HTTP/1.1
Accept:*/*
Cache-Control:no-cache
Connection:Keep-Alive
Host:www.zf08.net
Pragma:no-cache
Range:bytes=217888-227644
User-Agent:Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1; SV1; .NET CLR 1.1.4322; .NET CLR 2.0.50727)
[/code]
迅雷是通过Range:bytes=217888-227644来把文件分割下载的。但是如何获取总长度还不清楚,response里也没返回。
quote:GET /home/mxxyy/UpFile/Data.doc HTTP/1.1
Accept:*/*
Cache-Control:no-cache
Connection:Keep-Alive
Host:www.zf08.net
Pragma:no-cache
Range:bytes=217888-227644
User-Agent:Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1; SV1; .NET CLR 1.1.4322; .NET CLR 2.0.50727)
[/quote]