Golang解析邮件获取发件人和正文方法
时间:2026-02-16 22:04:44 227浏览 收藏
本文深入讲解了如何使用 Go 语言标准库(尤其是 net/mail)解析原始邮件内容,重点解决实际开发中常见的痛点:准确提取已解码的发件人信息和可读正文,同时直面 net/mail 不支持 multipart 结构解析、不自动处理 Base64/Quoted-Printable 编码及 RFC 2047 头部编码等限制;通过结合 mime、io、base64 等包的手动解码与分段处理技巧,并对比推荐更可靠的第三方方案(如 go-message),为开发者提供从简单纯文本邮件到复杂 HTML/附件混合邮件的一站式解析思路与实用代码范例。

Go 标准库 net/mail 可以解析符合 RFC 5322 的原始邮件文本(如 .eml 文件内容或 SMTP 接收的原始报文),提取发件人、主题、日期等头部字段,以及解码后的正文。但它不负责解析 multipart 结构(如附件、HTML/Plain 混合体)或自动处理 Base64/Quoted-Printable 编码——这些需配合 mime 和 io 相关包手动处理。
1. 解析邮件头:获取发件人(From)、主题(Subject)等
使用 mail.ReadMessage 读取 io.Reader(比如 strings.NewReader(rawEmail)),得到一个 *mail.Message。它的 Header 是一个映射,键为标准头字段名(忽略大小写),值是字符串切片(因头字段可重复)。注意:值仍是 RFC 2047 编码的原始字节(如 =?UTF-8?B?5L2g5aW9?=),需用 mail.ParseAddress 或 mime.DecodeWord 解码。
示例获取发件人:
from, err := msg.Header.AddressList("From")
if err == nil && len(from) > 0 {
// 自动解码 name 和 address(支持 RFC 2047)
senderName := from[0].Name // 如 "张三"
senderAddr := from[0].Address // 如 "zhangsan@example.com"
}
2. 提取纯文本正文:处理 Content-Type 和编码
net/mail 不解析 body,只提供 msg.Body(一个 io.Reader)。要读取正文,需结合 msg.Header.Get("Content-Type") 判断类型,并检查 "Content-Transfer-Encoding" 字段(如 base64, quoted-printable)进行解码。
- 若 Content-Type 是
text/plain或text/html,且无 multipart,则直接读取msg.Body并按编码解码 - 使用
mime.DecodeWord解码 header 中的字段(如 Subject) - 使用
base64.NewDecoder或quotedprintable.NewReader包装msg.Body再读取
3. 处理 multipart 邮件(含 HTML/Plain/附件)
大多数现代邮件是 multipart/alternative 或 multipart/mixed。此时 msg.Body 是原始 multipart 数据流,需用 mime.Reader(来自 net/http 或第三方库如 github.com/emersion/go-message)递归解析各部分。标准库 net/mail 本身不提供 multipart 解析能力。
简易做法(适用于简单 alternative):
- 读取整个
msg.Body到字节切片 - 用
mime.ParseMediaType解析Content-Type获取 boundary - 手动按 boundary 分割(不推荐,易出错)
- 更稳妥:用
github.com/emersion/go-message(专为邮件设计,兼容 RFC)
4. 完整小例子:解析简单 text/plain 邮件
以下代码解析一封无 multipart、Base64 编码的纯文本邮件:
import (
"bytes"
"encoding/base64"
"fmt"
"net/mail"
"strings"
)
func parseSimpleMail(raw string) {
r := strings.NewReader(raw)
msg, _ := mail.ReadMessage(r)
// 解析 From
from, _ := msg.Header.AddressList("From")
if len(from) > 0 {
fmt.Printf("发件人: %s <%s>\n", from[0].Name, from[0].Address)
}
// 解析 Subject(RFC 2047 解码)
subject := msg.Header.Get("Subject")
decoded, _ := mime.DecodeWord(subject)
fmt.Printf("主题: %s\n", decoded)
// 解码并读取正文(假设是 base64 text/plain)
encoding := strings.ToLower(msg.Header.Get("Content-Transfer-Encoding"))
body := msg.Body
if encoding == "base64" {
body = base64.NewDecoder(base64.StdEncoding, body)
}
plain, _ := io.ReadAll(body)
fmt.Printf("正文: %s\n", strings.TrimSpace(string(plain)))
}
文中关于的知识介绍,希望对你的学习有所帮助!若是受益匪浅,那就动动鼠标收藏这篇《Golang解析邮件获取发件人和正文方法》文章吧,也可关注golang学习网公众号了解相关技术文章。
-
505 收藏
-
503 收藏
-
502 收藏
-
502 收藏
-
502 收藏
-
462 收藏
-
388 收藏
-
293 收藏
-
350 收藏
-
234 收藏
-
219 收藏
-
479 收藏
-
147 收藏
-
156 收藏
-
143 收藏
-
499 收藏
-
349 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 485次学习