请问如何用'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'库下载文件(并且能知道网络文件的字节数和已经下载的字节数)。
求一个比较好的下载文件的范例。
请问如何用'net/http'库下载文件(并且能知道网络文件的字节数和已经下载的字节数)
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
2条回答 默认 最新
- Hooopo 2010-01-24 19:30关注
1.如果是你自己的文件你可以使用head方法先在返回的http header里获取长度,但是如果是别人服务器上的文件head方法是不会给你返回content-length的。
2.太大可以在request 里加入accept-encoding gzip选项,下载回来再解压。
3.看看迅雷怎么搞的..本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报
悬赏问题
- ¥15 #MATLAB仿真#车辆换道路径规划
- ¥15 java 操作 elasticsearch 8.1 实现 索引的重建
- ¥15 数据可视化Python
- ¥15 要给毕业设计添加扫码登录的功能!!有偿
- ¥15 kafka 分区副本增加会导致消息丢失或者不可用吗?
- ¥15 微信公众号自制会员卡没有收款渠道啊
- ¥15 stable diffusion
- ¥100 Jenkins自动化部署—悬赏100元
- ¥15 关于#python#的问题:求帮写python代码
- ¥20 MATLAB画图图形出现上下震荡的线条