今天做了一个小实验,之前参与的一个的活动里面采用了一个php写入base64的做法。现在改用了golang 写,发现golang 和base64 在这块资料有点少。因为需要结合到自身做的一些业务,所以今天尝试做了以下一个小实验。
golang 接收到前端发过来的base64的编码。这个编码是没有做特殊处理,没有采用fromdata的做法。做之前也查找了一些golang 的资料,发现里面真正写起来,还有不少东西和知识点。
其中包括时间的用法,随机数的用法,正则用法,文件保存的用法,字符串和整形转换。
下面简单封装了一个方法。
使用的时候将收到的base64 编码处理一下将
data:image/png;base64
去掉,获取到图片所需要的编码内容。
base64_image_content := "data:image/png;base64,iVBORw0KGgoAAAANS..........."
WriteFile("./image", base64_image_content)
//写入文件,保存
func WriteFile(path string, base64_image_content string) bool {
b, _ := regexp.MatchString(`^data:\s*image\/(\w+);base64,`, base64_image_content)
if !b {
return false
}
re, _ := regexp.Compile(`^data:\s*image\/(\w+);base64,`)
allData := re.FindAllSubmatch([]byte(base64_image_content), 2)
fileType := string(allData[0][1]) //png ,jpeg 后缀获取
base64Str := re.ReplaceAllString(base64_image_content, "")
date := time.Now().Format("2006-01-02")
if ok := IsFileExist(path + "/" + date); !ok {
os.Mkdir(path+"/"+date, 0666)
}
curFileStr := strconv.FormatInt(time.Now().UnixNano(), 10)
r := rand.New(rand.NewSource(time.Now().UnixNano()))
n := r.Intn(99999)
var file string = path + "/" + date + "/" + curFileStr + strconv.Itoa(n) + "." + fileType
byte, _ := base64.StdEncoding.DecodeString(base64Str)
err := ioutil.WriteFile(file, byte, 0666)
if err != nil {
log.Println(err)
}
return false
}
//判断文件是否存在
func IsFileExist(filename string) bool {
_, err := os.Stat(filename)
if os.IsNotExist(err) {
return false
}
return true
}
实际上 前端可以将data:image/png;base64 去掉再传给后端存储,所以golang在一部分逻辑里面可以省去判断了。当然这个看谁让步来做。不是前端就是后端来做处理了。
由于本身对golang 还不熟悉,加上强类型,写起来很多东西要做处理。或者用熟悉了后再做处理好一点。
golang 封装了ioutil,实际上还是调用了os方法。
版权声明:本文为hero82748274原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。