fix: fix base64 image parse error (#858)
This commit is contained in:
parent
b7fcb319da
commit
a763681c2e
@ -1,6 +1,8 @@
|
|||||||
package image
|
package image
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"bytes"
|
||||||
|
"encoding/base64"
|
||||||
"image"
|
"image"
|
||||||
_ "image/gif"
|
_ "image/gif"
|
||||||
_ "image/jpeg"
|
_ "image/jpeg"
|
||||||
@ -8,6 +10,7 @@ import (
|
|||||||
"net/http"
|
"net/http"
|
||||||
"regexp"
|
"regexp"
|
||||||
"strings"
|
"strings"
|
||||||
|
"sync"
|
||||||
|
|
||||||
_ "golang.org/x/image/webp"
|
_ "golang.org/x/image/webp"
|
||||||
)
|
)
|
||||||
@ -29,13 +32,27 @@ var (
|
|||||||
reg = regexp.MustCompile(`data:image/([^;]+);base64,`)
|
reg = regexp.MustCompile(`data:image/([^;]+);base64,`)
|
||||||
)
|
)
|
||||||
|
|
||||||
|
var readerPool = sync.Pool{
|
||||||
|
New: func() interface{} {
|
||||||
|
return &bytes.Reader{}
|
||||||
|
},
|
||||||
|
}
|
||||||
|
|
||||||
func GetImageSizeFromBase64(encoded string) (width int, height int, err error) {
|
func GetImageSizeFromBase64(encoded string) (width int, height int, err error) {
|
||||||
encoded = strings.TrimPrefix(encoded, "data:image/png;base64,")
|
decoded, err := base64.StdEncoding.DecodeString(reg.ReplaceAllString(encoded, ""))
|
||||||
base64 := strings.NewReader(reg.ReplaceAllString(encoded, ""))
|
|
||||||
img, _, err := image.DecodeConfig(base64)
|
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return
|
return 0, 0, err
|
||||||
}
|
}
|
||||||
|
|
||||||
|
reader := readerPool.Get().(*bytes.Reader)
|
||||||
|
defer readerPool.Put(reader)
|
||||||
|
reader.Reset(decoded)
|
||||||
|
|
||||||
|
img, _, err := image.DecodeConfig(reader)
|
||||||
|
if err != nil {
|
||||||
|
return 0, 0, err
|
||||||
|
}
|
||||||
|
|
||||||
return img.Width, img.Height, nil
|
return img.Width, img.Height, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -152,3 +152,20 @@ func TestGetImageSize(t *testing.T) {
|
|||||||
})
|
})
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func TestGetImageSizeFromBase64(t *testing.T) {
|
||||||
|
for i, c := range cases {
|
||||||
|
t.Run("Decode:"+strconv.Itoa(i), func(t *testing.T) {
|
||||||
|
resp, err := http.Get(c.url)
|
||||||
|
assert.NoError(t, err)
|
||||||
|
defer resp.Body.Close()
|
||||||
|
data, err := io.ReadAll(resp.Body)
|
||||||
|
assert.NoError(t, err)
|
||||||
|
encoded := base64.StdEncoding.EncodeToString(data)
|
||||||
|
width, height, err := img.GetImageSizeFromBase64(encoded)
|
||||||
|
assert.NoError(t, err)
|
||||||
|
assert.Equal(t, c.width, width)
|
||||||
|
assert.Equal(t, c.height, height)
|
||||||
|
})
|
||||||
|
}
|
||||||
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user