Browse Source

feat: drains http body if buffer is too small

Signed-off-by: divinerapier <poriter.coco@gmail.com>
pull/1173/head
divinerapier 5 years ago
parent
commit
4cbb6fa199
No known key found for this signature in database GPG Key ID: EA114C69199EE3BB
  1. 10
      weed/util/http_util.go

10
weed/util/http_util.go

@ -235,8 +235,16 @@ func ReadUrl(fileUrl string, offset int64, size int, buf []byte, isReadRange boo
if err != nil { if err != nil {
return n, err return n, err
} }
if n == int64(len(buf)) {
break
}
} }
// drains the response body to avoid memory leak
data, err := ioutil.ReadAll(reader)
if len(data) != 0 {
err = fmt.Errorf("buffer size is too small. remains %d", len(data))
}
return n, err
} }
func ReadUrlAsStream(fileUrl string, offset int64, size int, fn func(data []byte)) (int64, error) { func ReadUrlAsStream(fileUrl string, offset int64, size int, fn func(data []byte)) (int64, error) {

Loading…
Cancel
Save