答案:使用 net/http 和 os 包发起 GET 请求并写入文件,通过 io.Copy 高效传输数据,可添加进度提示与超时控制。示例包含状态码检查、资源释放、错误处理及 defer 的正确使用,支持大文件流式下载,结合 context 可实现重试与断点续传。

在Golang中实现HTTP文件下载并不复杂,主要依赖标准库中的 net/http 和 os 包。通过发送GET请求获取远程文件内容,并将其写入本地文件即可完成下载。下面介绍具体实现方式和一些实用技巧。
使用 http.Get() 可以快速发起一个GET请求。关键是要检查响应状态码,并确保资源可读。
- 调用 http.Get(url) 获取响应示例代码:
resp, err := http.Get("https://example.com/file.zip")
if err != nil {
log.Fatal(err)
}
defer resp.Body.Close()
<p>if resp.StatusCode != http.StatusOK {
log.Fatalf("下载失败: %d", resp.StatusCode)
}使用 os.Create() 创建本地文件,然后通过 io.Copy() 将响应体写入磁盘,避免一次性加载整个文件到内存。
立即学习“go语言免费学习笔记(深入)”;
- os.Create 返回一个 *os.File完整写入逻辑:
file, err := os.Create("file.zip")
if err != nil {
log.Fatal(err)
}
defer file.Close()
<p>_, err = io.Copy(file, resp.Body)
if err != nil {
log.Fatal(err)
}对于大文件,用户可能希望看到下载进度。可以通过包装 resp.Body 实现进度追踪。
定义一个自定义的 io.Reader 来监听读取过程:
type progressReader struct {
r io.Reader
total int64
read int64
onRead func(read, total int64)
}
<p>func (pr *progressReader) Read(p []byte) (n int, err error) {
n, err = pr.r.Read(p)
pr.read += int64(n)
pr.onRead(pr.read, pr.total)
return
}使用时:
reader := &progressReader{
r: resp.Body,
total: resp.ContentLength,
onRead: func(read, total int64) {
fmt.Printf("已下载: %d / %d (%.2f%%)\r", read, total, float64(read)/float64(total)*100)
},
}
io.Copy(file, reader)生产环境中应设置HTTP客户端超时,防止长时间阻塞。
client := &http.Client{
Timeout: 30 * time.Second,
}
resp, err := client.Get("https://example.com/file.zip")基本上就这些。Golang的标准库足够强大,几行代码就能完成稳定可靠的文件下载功能。关键是合理管理资源、处理错误,并根据需要扩展功能如断点续传或并发下载。不复杂但容易忽略细节。
以上就是如何在Golang中实现HTTP文件下载_Golang HTTP文件下载实践的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号