golang语言实现的文件上传与文件下载功能示例
作者:李琼涛 发布时间:2023-06-19 00:05:31
标签:golang,文件上传,文件下载
本文实例讲述了golang实现的文件上传与文件下载功能。分享给大家供大家参考,具体如下:
upload.go
package common
import (
"io/ioutil"
"os"
"path"
"github.com/gin-gonic/gin"
"googo.co/goo"
"googo.co/utils"
)
const (
UPLOAD_DIR = "static/"
)
type Upload struct {
}
func (this Upload) DoHandle(c *gin.Context) *goo.Result {
fh, err := c.FormFile("file")
if err != nil {
return goo.Err(700, "上传失败:"+err.Error(), err.Error())
}
f, err := fh.Open()
if err != nil {
return goo.Err(701, "上传失败:"+err.Error(), err.Error())
}
defer f.Close()
bytes, err := ioutil.ReadAll(f)
if err != nil {
return goo.Err(702, "上传失败:"+err.Error(), err.Error())
}
md5File := utils.MD5(bytes)
fpath := md5File[0:2] + "/" + md5File[2:4] + "/"
if err := os.MkdirAll(UPLOAD_DIR+fpath, 0755); err != nil {
return goo.Err(703, "上传失败:"+err.Error(), err.Error())
}
fname := fpath + md5File[8:24] + path.Ext(fh.Filename)
fw, err := os.Create(UPLOAD_DIR + fname)
if err != nil {
return goo.Err(704, "上传失败:"+err.Error(), err.Error())
}
defer fw.Close()
if _, err := fw.Write(bytes); err != nil {
return goo.Err(705, "上传失败:"+err.Error(), err.Error())
}
return goo.Succ(gin.H{
"url": "/file/" + fname,
})
}
// 上传文件
r.POST("/upload", goo.Handler(common.Upload{}))
// 下载文件
r.StaticFS("/file", http.Dir("./static"))
// 访问
http://localhost:18000/file/ab/cd/efghijk.png
希望本文所述对大家Go语言程序设计有所帮助。
来源:https://my.oschina.net/qiongtaoli/blog/3064756


猜你喜欢
- 在我们使用log模块输出日志时,经常会遇到log输出重复的问题,如下:先来看这个文件log.py的代码:代码示例:''
- 本文实例讲述了go语言获取系统盘符的方法。分享给大家供大家参考。具体如下:涉及golang调用winapi获取系统盘符的技巧。代码如下://
- Go流程控制1、条件语句IF1、简单格式(不支持三目运算符)if 布尔表达式 { // 执行语句}2、if里面包含多个表达式的时
- 索引优化,查询优化,查询缓存,服务器设置优化,操作系统和硬件优化,应用层面优化(web服务器,缓存)等等。这里的记录的优化技巧更适用于开发人
- 本文实例讲述了Python实现统计给定字符串中重复模式最高子串功能。分享给大家供大家参考,具体如下:给定一个字符串,如何得到其中重复模式最高
- 以下是演示**“如何在Python中复制文件”的九种方法**。shutil copyfile()方法shutil copy()方法shuti
- my.ini 是啥玩意?my.ini是MySQL数据库中使用的配置文件,修改这个文件可以达到更新配置的目的。my.ini 在哪放着呢?my.
- 假设mysql 安装在c:盘,mysql数据库的用户名是root,密码是123456,数据库名是database_name,在d:盘根目录下
- 一、问题描述最近遇到一个问题,也就是使用分区表进行数据查询/加载的时候比普通表的性能下降了约50%,主要瓶颈出现在CPU,既然是CPU瓶颈理
- 概述在数据库当中,索引就跟树的目录一样用来加快数据的查找速度,对于一个SQL查询操作,根据索引快速过滤掉不符合要求的数据并定位到符合要求的数
- 装饰器总结什么是装饰器?处理函数的函数,加一个功能,但是不影响原来函数的内部结构生活中的例子:给手机加一个外壳,外壳保护了手机装饰器有什么用
- 一,为了让xadmin 登录者只能看到自己创建的数据1,modelclass UserTB(models.Model): nam
- Vue在目前是很好的框架,第一次使用Vue开发项目,刚开始的时候在一个控制开关的组件都花费了很久的时间,问题解决了,把自己的一些小问题给记录
- 如下所示:#待处理列表A= [1,2,3,4,5]#移动次数a = 3右移比较简单for i in range(a): A.insert(0
- 看到网上一片文章,自己式了一下,果然 XMLTextReader速度要快!在.NET框架的System.XML名称空间中包含的XMLText
- 我就废话不多说了,大家还是直接看代码吧~import kerasfrom sklearn.model_selection import tr
- 有人可能会问,为什么9号出现的补丁,到现在才发现问题?大家都知道,服务器不是每天都重启的,有的服务器可能一个月或者一年半载重启一次,有的可能
- #coding=utf-8__auther__ = 'xianbao'import sqlite3# 打开数据库def op
- 如下所示:#文件内容 lisilock = open("lock_info.txt", "r+",e
- 有如下格式的文本文件/“/请/!/”/“/请/!/”/两名/剑士/各自/倒转/剑尖/,/右手/握/剑柄/,/左手/搭于/右手/手背/,/躬身