Go标准库mime包核心功能是解析、匹配与注册MIME类型,不处理完整邮件或HTTP报文;需配合net/mail、net/http等包使用,主要提供ParseMediaType、IsMedia、TypeByExtension及AddExtensionType等函数。
Go 标准库的 mime 包主要用于 MIME 类型的解析、匹配与注册,但它本身不负责解析完整邮件或 HTTP 报文。真正处理邮件(如 RFC 5322/2045)和 HTTP 内容(如请求头中的 Content-Type)时,需结合 net/mail、net/http 等包协同工作。mime 的核心作用是:解析 MIME 类型字符串(如 "text/html; charset=utf-8"),判断子类型是否匹配(如 IsMedia)、注册自定义类型、以及辅助生成合法的 MIME 头字段。
mime.ParseMediaType() 是最常用函数,它将完整的 Content-Type 字符串拆解为类型、子类型和参数映射:
"text")、子类型(如 "html")和参数(如 map[string]string{"charset
": "utf-8"})示例:
content := "multipart/mixed; boundary=\"xyz123\"; charset=utf-8"mime.TypeByExtension() 和 mime.MatchExtension() 可根据文件扩展名反查或匹配类型;而更通用的分类判断靠 mime.IsMedia()(Go 1.22+)或手动比对:
mime.IsMedia("text/plain") 返回 true(属于标准媒体类型)"application/vnd.myapp+json"),需用 strings.HasPrefix() 判断主类型或子类型模式邮件正文常含 multipart/mixed 或 multipart/alternative 结构,net/mail 的 ReadMIMEHeader() 和 multipart.NewReader() 依赖 mime 解析 boundary 和类型:
net/mail.ReadMessage() 获取邮件头,从中提取 Content-Type 字段mime.ParseMediaType() 得到 boundary 值,再传给 multipart.NewReader(r, boundary)
multipart.Part 自带 Header,其中 part.Header.Get("Content-Type") 需再次用 mime.ParseMediaType() 解析子部分类型注意:boundary 必须严格匹配(包括引号和空格),mime.ParseMediaType 已正确处理这些细节。
当系统未识别某扩展名(如 .webp 或 .toml)时,可用 mime.AddExtensionType() 手动注册:
mime.TypeByExtension(".webp") 就能返回 "image/webp"
init() 函数中注册,避免并发问题TypeByExtension 和 ExtensionByType,不影响 ParseMediaType
示例:
func init() {
mime.AddExtensionType(".toml", "application/toml")
}