客戶端:
//const ( // UA = "Golang Downloader from Kejibo.com" //) func DownloadController(ctx *gin.Context) { f, err := os.OpenFile("./file.exe", os.O_RDWR|os.O_CREATE, 0666) //O_RDWR|O_CREATE,也就是文件不存在的情況下就建一個空文件,因為windows下還有BUG,如果使用這個O_CREATE,就會直接清空文件,所以windows不用這個標志,你自己事先建立好文件。 if err != nil { panic(err) } stat, err := f.Stat() //獲取文件狀態 if err != nil { panic(err) } f.Seek(stat.Size(), 0) //把文件指針指到文件末,當然你說為何不直接用 O_APPEND 模式打開,沒錯是可以。我這里只是試驗。 //f.Seek(int64(os.O_APPEND), 0) url1 := "http://dl.google.com/chrome/install/696.57/chrome_installer.exe" var req http.Request req.Method = "GET" //req.UserAgent = UA //客戶端信息字符串,不過我加上UserAgent,一直報錯,不知道怎么回事,暫時不用它 req.Close = true req.URL, err = url.Parse(url1) if err != nil { panic(err) } header := http.Header{} header.Set("Range", "bytes="+strconv.FormatInt(stat.Size(), 10)+"-") req.Header = header resp, err := http.DefaultClient.Do(&req) if err != nil { panic(err) } written, err := io.Copy(f, resp.Body) if err != nil { panic(err) } println("written: ", written) }
另外一個例子:
傳送門:https://blog.csdn.net/luckytanggu/article/details/79830493
無斷點續傳:https://www.jianshu.com/p/b49cc19d26f0