go语言通过net/http和multipart解析实现文件上传,需设置表单enctype为multipart/form-data,服务端用r.ParseMultipartForm解析并调用r.FormFile获取文件句柄。

在go语言中实现文件上传功能,主要依赖标准库中的 net/http 和文件操作相关包。通过解析HTTP请求中的 multipart 表单数据,可以接收客户端上传的文件,并将其保存到服务器指定路径。以下是具体实现步骤和示例代码。
处理Multipart表单上传
html表单需要设置 enctype=”multipart/form-data”,以便正确传输文件数据。Go服务端使用 r.ParseMultipartForm() 解析请求,然后通过 r.FormFile() 获取上传的文件句柄。
示例html表单:
<form enctype="multipart/form-data" action="/upload" method="post"> <input type="file" name="myfile" /> <input type="submit" value="上传" /> </form>
对应的Go服务端处理函数:
立即学习“go语言免费学习笔记(深入)”;
func uploadHandler(w http.ResponseWriter, r *http.Request) {     if r.Method != "POST" {         http.Error(w, "只允许POST请求", http.StatusMethodNotAllowed)         return     }      // 解析 multipart 表单,最大内存为32MB     err := r.ParseMultipartForm(32 << 20)     if err != nil {         http.Error(w, err.Error(), http.StatusBadRequest)         return     }      // 获取名为 myfile 的文件     file, handler, err := r.FormFile("myfile")     if err != nil {         http.Error(w, "无法获取文件", http.StatusBadRequest)         return     }     defer file.Close()      // 创建本地文件用于保存     dst, err := os.Create("./uploads/" + handler.Filename)     if err != nil {         http.Error(w, "无法创建本地文件", http.StatusInternalServerError)         return     }     defer dst.Close()      // 将上传的文件内容复制到本地文件     _, err = io.Copy(dst, file)     if err != nil {         http.Error(w, "保存文件失败", http.StatusInternalServerError)         return     }      fmt.Fprintf(w, "文件 %s 上传成功", handler.Filename) } 
确保目录存在并限制文件大小
在保存文件前,应检查上传目录是否存在,若不存在则自动创建。同时,可通过控制 ParseMultipartForm 的参数来限制请求体大小,防止恶意大文件上传。
- 使用 os.MkdirAll() 确保上传目录可用
- 设置合理的内存与磁盘缓存阈值(如 32MB)
- 可进一步校验文件类型或扩展名
注册路由并启动服务
将上传处理器绑定到指定路由,并启动HTTP服务:
func main() {     http.HandleFunc("/upload", uploadHandler)     http.Handle("/", http.FileServer(http.Dir("."))) // 可选:提供静态页面      fmt.Println("服务运行在 :8080")     log.Fatal(http.ListenAndServe(":8080", nil)) } 
只要客户端发送符合规范的 multipart 请求,Go服务就能安全地接收并保存文件。基本上就这些,不复杂但容易忽略目录权限和错误处理。


