使用net/http和文件操作实现图像上传;2. 创建含multipart表单的HTML页面;3. Go后端解析文件并保存;4. 支持图片展示功能。

在Golang中实现基础的图像上传与展示功能并不复杂,只需使用标准库中的 net/http 和文件操作相关功能即可完成。下面是一个简单、实用的实现方式,包含前端表单、后端接收、文件保存和图片展示。
1. 创建图像上传表单
首先,准备一个简单的HTML页面,允许用户选择并上传图片:
注意:必须设置 enctype="multipart/form-data",否则文件无法正确提交。
2. 处理图像上传
在Go服务端,通过 http.Request 的 ParseMultipartForm 方法解析上传的文件:
立即学习“go语言免费学习笔记(深入)”;
func uploadHandler(w http.ResponseWriter, r *http.Request) {
if r.Method != "POST" {
http.Error(w, "只支持 POST 请求", http.StatusMethodNotAllowed)
return
}
// 解析 multipart 表单,最大内存 10MB
r.ParseMultipartForm(10 << 20)
file, handler, err := r.FormFile("image")
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()
// 将上传的文件内容复制到本地
io.Copy(dst, file)
fmt.Fprintf(w, "文件 %s 上传成功", handler.Filename)
}
确保项目根目录下有 uploads 文件夹,或在程序中动态创建:
BJXSHOP购物管理系统是一个功能完善、展示信息丰富的电子商店销售平台;针对企业与个人的网上销售系统;开放式远程商店管理;完善的订单管理、销售统计、结算系统;强力搜索引擎支持;提供网上多种在线支付方式解决方案;强大的技术应用能力和网络安全系统 BJXSHOP网上购物系统 - 书店版,它具备其他通用购物系统不同的功能,有针对图书销售而进行开发的一个电子商店销售平台,如图书ISBN,图书目录
os.MkdirAll("uploads", os.ModePerm)
3. 展示已上传的图片
要展示图片,最简单的方法是将 uploads 目录设为静态文件服务路径:
// 将 /images/ 路由指向 uploads 目录
http.Handle("/images/", http.StripPrefix("/images/", http.FileServer(http.Dir("uploads/"))))
// 示例访问:http://localhost:8080/images/filename.jpg
也可以提供一个页面列出所有已上传图片:
func listImages(w http.ResponseWriter, r *http.Request) {
files, _ := filepath.Glob("uploads/*")
var imageLinks string
for _, f := range files {
filename := filepath.Base(f)
imageLinks += fmt.Sprintf("@@##@@", filename)
}
fmt.Fprintf(w, "已上传图片
%s", imageLinks)
}
4. 完整主函数示例
package main
import (
"fmt"
"io"
"net/http"
"os"
"path/filepath"
)
func main() {
os.MkdirAll("uploads", os.ModePerm)
http.HandleFunc("/upload", uploadHandler)
http.HandleFunc("/images", listImages)
http.Handle("/images/", http.StripPrefix("/images/", http.FileServer(http.Dir("uploads/"))))
fmt.Println("服务器启动在 :8080")
http.ListenAndServe(":8080", nil)
}
运行程序后,访问 http://localhost:8080(可配合前端页面),上传图片后可通过 /images/xxx.jpg 直接访问,或访问 /images 查看所有图片缩略图。
基本上就这些。不复杂但容易忽略的是文件类型检查、重命名避免冲突、大小限制等安全措施,生产环境建议加上。当前实现适合学习和原型开发。









