package utils import ( "encoding/base64" "fmt" "io/ioutil" "net/http" ) const ( Base64Std = iota Base64Url Base64RawStd Base64RawUrl ) func Base64StdEncode(str interface{}) string { return Base64Encode(str, Base64Std) } func Base64StdDecode(str interface{}) string { return Base64Decode(str, Base64Std) } func Base64UrlEncode(str interface{}) string { return Base64Encode(str, Base64Url) } func Base64UrlDecode(str interface{}) string { return Base64Decode(str, Base64Url) } func Base64RawStdEncode(str interface{}) string { return Base64Encode(str, Base64RawStd) } func Base64RawStdDecode(str interface{}) string { return Base64Decode(str, Base64RawStd) } func Base64RawUrlEncode(str interface{}) string { return Base64Encode(str, Base64RawUrl) } func Base64RawUrlDecode(str interface{}) string { return Base64Decode(str, Base64RawUrl) } func Base64Encode(str interface{}, encode int) string { newEncode := base64Encode(encode) if newEncode == nil { return "" } switch v := str.(type) { case string: return newEncode.EncodeToString([]byte(v)) case []byte: return newEncode.EncodeToString(v) } return newEncode.EncodeToString([]byte(fmt.Sprint(str))) } func Base64Decode(str interface{}, encode int) string { var err error var b []byte newEncode := base64Encode(encode) if newEncode == nil { return "" } switch v := str.(type) { case string: b, err = newEncode.DecodeString(v) case []byte: b, err = newEncode.DecodeString(string(v)) default: return "" } if err != nil { return "" } return string(b) } func base64Encode(encode int) *base64.Encoding { switch encode { case Base64Std: return base64.StdEncoding case Base64Url: return base64.URLEncoding case Base64RawStd: return base64.RawStdEncoding case Base64RawUrl: return base64.RawURLEncoding default: return nil } } func GetBase64FromUrlForImage(url string) (string, error) { res, err := http.Get(url) if err != nil { return "", err } defer res.Body.Close() data, _ := ioutil.ReadAll(res.Body) imageBase64 := base64.StdEncoding.EncodeToString(data) return imageBase64, nil }