content-encoding
parent
b63288dae0
commit
d254512f25
@ -0,0 +1,73 @@
|
||||
package flow
|
||||
|
||||
import (
|
||||
"bytes"
|
||||
"compress/gzip"
|
||||
"errors"
|
||||
"io"
|
||||
)
|
||||
|
||||
// handle http header: content-encoding
|
||||
|
||||
var EncodingNotSupport = errors.New("content-encoding not support")
|
||||
|
||||
func (r *Response) DecodedBody() ([]byte, bool) {
|
||||
if r.decodedBody != nil {
|
||||
return r.decodedBody, r.decoded
|
||||
}
|
||||
|
||||
if r.decodedErr != nil {
|
||||
return nil, r.decoded
|
||||
}
|
||||
|
||||
if r.Body == nil {
|
||||
return nil, r.decoded
|
||||
}
|
||||
|
||||
if len(r.Body) == 0 {
|
||||
r.decodedBody = r.Body
|
||||
return r.decodedBody, r.decoded
|
||||
}
|
||||
|
||||
enc := r.Header.Get("Content-Encoding")
|
||||
if enc == "" {
|
||||
r.decodedBody = r.Body
|
||||
return r.decodedBody, r.decoded
|
||||
}
|
||||
|
||||
r.decodedBody, r.decodedErr = Decode(enc, r.Body)
|
||||
if r.decodedErr != nil {
|
||||
log.Error(r.decodedErr)
|
||||
} else {
|
||||
r.decoded = true
|
||||
}
|
||||
|
||||
return r.decodedBody, r.decoded
|
||||
}
|
||||
|
||||
// 当 Response.Body 替换为解压的内容时调用
|
||||
func (r *Response) RemoveEncodingHeader() {
|
||||
r.Header.Del("Content-Encoding")
|
||||
r.Header.Del("Content-Length")
|
||||
}
|
||||
|
||||
func Decode(enc string, body []byte) ([]byte, error) {
|
||||
if enc == "gzip" {
|
||||
zr, err := gzip.NewReader(bytes.NewReader(body))
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
buf := bytes.NewBuffer(make([]byte, 0))
|
||||
_, err = io.Copy(buf, zr)
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
err = zr.Close()
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
return buf.Bytes(), nil
|
||||
}
|
||||
|
||||
return nil, EncodingNotSupport
|
||||
}
|
Loading…
Reference in New Issue