No description
Find a file
2026-04-24 12:59:31 +08:00
.github/workflows ci: 添加 main 自动合并到 dev 工作流 2026-04-20 07:40:24 +08:00
__pycache__ 初始化 2026-01-13 20:23:55 +08:00
docs 新增时区设置 2026-04-22 14:02:12 +08:00
img 更新文档 2026-04-11 09:07:32 +08:00
outlook_web release: 2.0.31 2026-04-24 09:55:06 +08:00
static release: 2.0.32 2026-04-24 12:59:31 +08:00
templates release: 2.0.29 2026-04-23 01:07:03 +08:00
tests release: 2.0.31 2026-04-24 09:55:06 +08:00
.dockerignore 增加docker部署方式 2026-01-20 20:40:18 +08:00
.env.example feat: use frontend localStorage for default provider and group selection 2026-02-24 16:21:35 +08:00
.gitignore 修复2925邮件详情问题 2026-04-15 21:55:29 +08:00
BRANCH_PROTECTION.md chore: tighten image build triggers and add branch protection guide 2026-04-07 12:02:39 +02:00
CHANGELOG.md release: 2.0.32 2026-04-24 12:59:31 +08:00
Dockerfile Improve Docker resilience for IMAP fallback 2026-04-07 13:42:29 +08:00
outlook_mail_reader.py imap新增超时配置 2026-04-11 00:53:08 +08:00
outlookEmail.spec chore: release v2.0.4 2026-04-11 22:07:38 +08:00
README.md 补充常见问题 2026-04-15 12:43:20 +08:00
RELEASE.md - 修改发布流程,支持推送 vX.Y.Z 版本标签后自动触发 GitHub Release 工作流,手动触发改为兜底方案。 2026-04-15 15:41:57 +08:00
requirements.txt chore: release v2.0.7 2026-04-11 22:52:24 +08:00
VERSION release: 2.0.32 2026-04-24 12:59:31 +08:00
web_outlook_app.py chore: release v2.0.4 2026-04-11 22:07:38 +08:00

多邮箱邮件管理工具

一个面向多邮箱账号场景的邮件管理工具,支持通过 Outlook/Hotmail OAuth、Microsoft Graph API 和标准 IMAP 统一读取、管理和转发邮件,并提供 Web 界面用于分组管理、账号管理、邮件查看和对外 API 调用。当前支持 Outlook/Hotmail、Gmail、QQ、163、126、Yahoo、阿里邮箱以及自定义 IMAP 邮箱,同时集成 GPTMail、DuckMail、Cloudflare Temp Email 多提供商临时邮箱能力。

📦 快速开始

体验站点

https://aso.de5.net admin123 注意:体验站点请勿修改密码或存放实际数据,部署在无持久化的服务上,数据随时可能丢失恢复初始状态

🌿 版本管理与发布

本项目采用轻量化双分支版本管理:

  • main:稳定分支,只保留可发布版本
  • dev:开发分支,日常功能开发与修复默认在这里进行

标准发版流程:

  1. dev 分支完成开发与验证
  2. 合并到 main
  3. 更新 VERSIONCHANGELOG.md
  4. 推送 main
  5. 手动触发 GitHub Actions 的 Create GitHub Release 工作流,并传入不带 v 的版本号,例如 2.0.15

手动发版工作流会自动:

  • 构建 Windows exe 并打包为 Release 附件
  • 创建并推送对应标签,例如 v2.0.15
  • 根据 CHANGELOG.md 中对应版本条目生成 GitHub Release 正文
  • 构建并发布正式版本镜像 ghcr.io/assast/outlookemail:v2.0.15

Docker 镜像标签约定:

  • ghcr.io/assast/outlookemail:latest:默认分支最近一次符合条件的稳定构建
  • ghcr.io/assast/outlookemail:mainmain 分支最近一次符合条件的构建
  • ghcr.io/assast/outlookemail:devdev 分支最近一次符合条件的构建
  • ghcr.io/assast/outlookemail:vX.Y.Z:正式版本镜像

更完整的发版步骤、工作流行为和核对清单见 发版说明

方式一:下载 Windows exe(win可用)

从 GitHub Releases 下载对应版本的 OutlookEmail-windows-x64-*.zip,解压后直接运行 OutlookEmail.exe 即可。

桌面版首次启动会自动:

  • 生成并持久化 SECRET_KEY
  • 创建本地数据目录和 SQLite 数据库
  • 启动 Web 服务,默认地址 http://127.0.0.1:5000

说明:

  • Windows 数据默认保存在 %APPDATA%\OutlookEmail
  • 默认登录密码仍然是 admin123,首次登录后建议立即修改

方式二:使用 Docker推荐服务器部署

# 拉取最新镜像
docker pull ghcr.io/assast/outlookemail:latest

# 运行容器
docker run -d \
  --name outlook-mail-reader \
  -p 5000:5000 \
  -v $(pwd)/data:/app/data \
  -e LOGIN_PASSWORD=admin123 \
  -e SECRET_KEY=your-secret-key-here \
  ghcr.io/assast/outlookemail:latest

方式三:使用 Python 直接运行

git clone https://github.com/assast/outlookEmail.git
cd outlookEmail
pip install -r requirements.txt
export SECRET_KEY=your-secret-key-here
python web_outlook_app.py

访问 http://localhost:5000 即可使用。 如果是服务器部署,仍然建议显式设置固定 SECRET_KEY

使用 Docker Compose

version: '3.8'
services:
  outlook-mail-reader:
    image: ghcr.io/assast/outlookemail:latest
    container_name: outlook-mail-reader
    ports:
      - "5000:5000"
    volumes:
      - ./data:/app/data
    environment:
      - LOGIN_PASSWORD=admin123
      - SECRET_KEY=your-secret-key-here
      - FLASK_ENV=production
    restart: unless-stopped
docker-compose up -d

功能特性

邮件读取方式

本工具当前包含三类读取链路:

  1. Outlook/Hotmail OAuth + Graph API - 优先方式,适合 Outlook / Hotmail / Live 账号
  2. Outlook/Hotmail OAuth + IMAP 回退 - outlook.live.com / outlook.office365.com
  3. 标准 IMAP - 适用于 Gmail、QQ、163、126、Yahoo、阿里邮箱和自定义 IMAP

Web 应用功能

核心功能

  • 🔐 登录验证 - 密码保护的 Web 界面,支持在线修改密码
  • 📁 分组管理 - 支持创建、编辑、删除邮箱分组,自定义分组颜色,支持分组级别代理设置
  • 🌐 分组代理 - 每个分组可配置 HTTP/SOCKS5 代理
  • 📧 多邮箱管理 - 批量导入和管理 Outlook/Hotmail OAuth / IMAP 邮箱账号
  • 🪪 别名管理 - 支持给单个邮箱配置多个别名邮箱,主邮箱和别名都可用于检索邮件和调用对外 API
  • 🔀 别名高级用法 - 可将外部邮箱自动转发到本项目管理的邮箱 A再把外部邮箱配置为 A 的别名,从而通过本项目统一读取邮件
  • 📬 邮件查看 - Web 界面支持查看收件箱和垃圾邮件API 支持 inboxjunkemaildeleteditemsall
  • 🔍 全屏查看 - 支持全屏模式查看邮件
  • 📤 导出功能 - 支持按分组或全部导出邮箱账号信息
  • 🎨 现代化 UI - 四栏布局,账号列表、邮件列表、邮件详情分区清晰
  • 性能优化 - 邮件列表与账号列表缓存,分组切换和账号切换更快
  • 📄 分页加载 - 滚动到底部自动加载下一页每页20封
  • 🔥 临时邮箱 - 集成 GPTMail + DuckMail + Cloudflare Temp Email多提供商生成、导入、读取和查看详情
  • ⚙️ 系统设置 - 在线修改密码、API Key 等
  • 🔄 OAuth2 助手 - 内置授权流程,快速获取 Refresh Token
  • 💾 邮件缓存 - 智能缓存邮件列表,切换即时展示
  • 🏷️ 标签管理 - 支持给邮箱打标签、批量操作、按标签筛选
  • 📦 批量移动分组 - 批量选择邮箱移动到指定分组
  • 批量选择 - 邮箱列表、邮件列表均支持全选当前列表与清空选择
  • 🗑️ 邮件删除 - 单封/批量永久删除邮件
  • 🔄 API 优先级回退 - Graph API → IMAP(新) → IMAP(旧) 自动回退
  • 🔑 对外 API - 通过 API Key 直接获取邮件,无需登录,支持别名邮箱、聚合文件夹和多条件筛选 带+号的附加电子邮箱自动识别,自动回退主邮箱/别名邮箱查询

邮件转发

  • 📮 按账号开启转发 - 每个账号单独控制是否参与自动转发
  • 📨 多渠道转发 - 支持 SMTP 邮件转发和 Telegram 转发
  • ⏱️ 时间窗口控制 - 支持仅转发最近 X 分钟内收到的邮件
  • 🗑️ 垃圾箱转发可选 - 可配置是否把垃圾邮件一起纳入转发
  • 📚 转发历史 - 支持查看最近转发记录和失败记录
  • ▶️ 手动触发 - 支持从界面手动触发一次转发检查

Token 刷新管理

  • 🔁 全量刷新 - 一键刷新所有 Outlook/Hotmail OAuth 账号 Token
  • 定时刷新 - 支持按天数或 Cron 表达式配置Docker / Docker Compose 启动也会自动生效
  • 📊 刷新统计 - 实时显示失败邮箱数量
  • 📜 刷新历史 - 近半年完整记录

安全特性

  • 🛡️ XSS 防护 | 🔒 CSRF 防护 | 🔐 数据加密 | 🚦 速率限制 | 📋 审计日志 | 🔑 二次验证

界面布局

Web 应用采用四栏式布局设计:

  1. 分组面板 - 显示所有邮箱分组,点击切换
  2. 邮箱面板 - 显示当前分组下的邮箱账号列表
  3. 邮件列表 - 显示选中邮箱的邮件,支持切换文件夹和滚动加载
  4. 邮件详情 - 显示选中邮件的完整内容(支持 HTML 渲染)

📸 界面预览

邮箱列表界面

邮箱列表

全局搜索功能

全局搜索

导入邮箱账号

导入邮箱账号

Token 刷新管理

全量刷新Token

标签管理功能

标签管理

📖 使用说明

1. 获取 OAuth2 凭证(这一步非必须,买的账号如果是带令牌的可以跳过这一步)

要使用本工具,您需要获取以下 OAuth2 凭证:

  1. Client ID - Microsoft Azure 应用注册的客户端 ID
  2. Refresh Token - OAuth2 刷新令牌

步骤 1注册 Azure 应用这一步看目前的情况得E3 或者 E5 或者其他的开发者账号才能创建)

访问 Azure Portal,进入「应用注册」:

应用注册

步骤 2创建新应用

点击「新注册」,填写应用信息:

注册应用程序

  • 名称:自定义应用名称
  • 支持的账户类型:选择「任何组织目录中的账户和个人 Microsoft 账户」
  • 重定向 URI:选择「公共客户端/本机」,填写 http://localhost:8080

步骤 3获取应用程序 ID

创建完成后,复制「应用程序(客户端) ID」

获取应用程序ID

步骤 4配置 API 权限 这一步应该可以省略目前内置的客户端id就没有设置这一步也能正常使用

在「API 权限」中添加以下权限:

  • offline_access - 获取刷新令牌
  • Mail.Read - 读取邮件
  • Mail.ReadWrite - 读写邮件
  • User.Read - 读取用户信息
  • IMAP.AccessAsUser.All - IMAP 访问

步骤 5获取 Refresh Token

使用本工具内置的 OAuth2 助手获取 Refresh Token

换取token

  1. 在 Web 界面点击「获取 Token」按钮
  2. 点击「生成授权链接」
  3. 复制链接到浏览器打开,完成授权
  4. 复制授权后的完整 URL处于安全考虑我没有统一建设授权回调服务所有授权都在自己部署的服务内完成不会外泄所以重定向URI为http://localhost:8080这个链接肯定是打不开的所以要复制过来在部署的服务走后半段的换取Refresh Token
  5. 粘贴到「授权后的 URL」输入框
  6. 点击「换取 Token」按钮
  7. 复制获得的 Refresh Token

2. 导入邮箱账号

在 Web 界面中点击「导入邮箱」后,可根据邮箱类型选择对应导入格式。

Outlook/Hotmail OAuth

支持两种格式:

邮箱----密码----client_id----refresh_token
邮箱----密码----refresh_token----client_id

示例:

user@outlook.com----password123----24d9a0ed-8787-4584-883c-2fd79308940a----0.AXEA...

标准 IMAP 邮箱

适用于 Gmail、QQ、163、126、Yahoo、阿里邮箱等

邮箱----IMAP授权码/应用密码

示例:

user@gmail.com----app-password
user@qq.com----imap-auth-code

自定义 IMAP

支持两种格式:

邮箱----IMAP密码
邮箱----IMAP密码----imap_host----imap_port

示例:

user@example.com----app-password
user@example.com----app-password----imap.example.com----993

支持批量导入,每行一个账号。导入时可选择是否立即开启邮件转发。普通邮箱导入时不能选择临时邮箱分组。

3. 查看邮件

  1. 从左侧选择分组
  2. 选择邮箱账号
  3. 点击「获取邮件」按钮
  4. 在 Web 界面切换「收件箱」「垃圾邮件」查看邮件
  5. 滚动到邮件列表底部自动加载下一页(每页 20 封)
  6. 点击邮件查看详情,支持 HTML 渲染与全屏查看
  7. 需要查看 deleteditemsall 聚合结果时,建议使用对外 API 或内部 API

4. 别名管理

  1. 打开某个邮箱账号的「编辑账号」
  2. 在「别名邮箱」中按行填写多个别名
  3. 保存后,主邮箱和别名都会指向同一个账号

适合这些场景:

  • 同一账号有多个注册邮箱名称
  • 某些站点使用了 user+tag@example.com
  • 外部邮箱自动转发到本项目管理邮箱后,希望继续用原邮箱名来取信

5. 邮件转发

邮件转发分成两层控制:

  1. 账号级开关 在导入账号或编辑账号时,选择是否为该账号开启转发
  2. 全局转发设置 在「设置 -> 邮件转发设置」中配置:
    • 轮询间隔
    • 转发邮件时间范围
    • 是否转发垃圾箱邮件
    • 转发渠道SMTP / Telegram
    • SMTP / Telegram 的具体参数

补充说明:

  • 转发轮询只处理“账号里已开启转发”的邮箱
  • 可以手动触发一次转发检查
  • 可以查看最近转发历史和失败记录

6. 对外 API

通过 API Key 直接获取邮件,无需登录 Web 界面。

当前额外支持:

  • 使用主邮箱或别名邮箱取信
  • folder=all 一次聚合收件箱和垃圾邮件并按标准化后的邮件时间倒序排序,top 按每个文件夹分别计算
  • 支持按主题、发件人、关键词筛选列表
  • 支持特殊字符别名,例如 user+alias@example.com
  • 默认 top=1

配置步骤:

  1. 点击「⚙️ 设置」→ 在「对外 API Key」处点击「🔑 随机生成」→ 保存

调用示例:

curl -H "X-API-Key: your-api-key" \
  "http://localhost:5000/api/external/emails?email=user@outlook.com&folder=inbox"

curl -H "X-API-Key: your-api-key" \
  "http://localhost:5000/api/external/emails?email=alias@example.com&folder=all&top=10"

curl -H "X-API-Key: your-api-key" \
  "http://localhost:5000/api/external/emails?email=alias@example.com&folder=all&top=10&subject_contains=verify&from_contains=github&keyword=reset"

curl -H "X-API-Key: your-api-key" \
  "http://localhost:5000/api/external/emails?email=user%2Balias%40example.com"

如果邮箱或别名里带特殊字符:

  • @ 可以直接传
  • + 建议编码成 %2B
  • & 必须编码成 %26

如果你把外部邮箱 B 自动转发到本项目管理的邮箱 A再把 B 配成 A 的别名,那么后续可以直接用 B 作为 email 参数调用对外 API。

详细文档见 API 文档

📚 详细文档

文档 说明
🚀 部署指南 Docker、Docker Compose、Nginx/Caddy 部署、环境变量配置
⬆️ 升级指南 Windows、Docker、Python 直跑升级与回滚建议
🔐 安全配置 XSS/CSRF 防护、数据加密、速率限制、审计日志
📡 API 文档 对外 API、内部 API 端点、代理配置
🛠️ 故障排查 常见问题、故障排查步骤
📋 更新日志 版本更新历史
🚢 发版说明 标准发版步骤、版本号规则、GitHub Release 说明
🛡️ 分支保护建议 main/dev 使用边界、保护规则与构建触发建议

🏗️ 技术架构

后端技术栈

  • Flask 3.0+ - Web 框架
  • SQLite 3 - 数据库
  • Requests / requests[socks] - HTTP 客户端与代理支持
  • IMAP4_SSL - IMAP 协议支持
  • Microsoft Graph API - Outlook/Hotmail 邮件 API
  • APScheduler + croniter - 定时刷新与转发轮询
  • bcrypt + cryptography - 密码哈希与敏感字段加密

前端技术栈

  • 原生 JavaScript - 无框架依赖
  • CSS3 - 现代化样式
  • Fetch API - 异步请求
  • DOMPurify 3.0.8 - HTML 净化

系统要求

  • Python 3.9+
  • SQLite 3
  • Docker可选
  • 2GB+ 内存

📝 依赖说明

flask>=3.0.0
flask-wtf>=1.2.0          # CSRF 防护(推荐安装)
werkzeug>=3.0.0
requests[socks]>=2.25.0   # HTTP 请求与代理支持
APScheduler>=3.10.0       # 定时任务
croniter>=1.3.0           # Cron 表达式解析
bcrypt>=4.0.0             # 密码哈希
cryptography>=41.0.0      # 数据加密

常见问题

Gmail怎么获取应用密码

开启2fa然后在这里创建应用密码

https://support.google.com/mail/answer/185833?hl=zh-Hans

怎么获取tg的群组id 和 用户id

获取个人 ID (User ID)

在 Telegram 搜索框搜索 @userinfobot 或 @getmyid_bot。

点击 Start。

机器人会立即回复你的 User ID一串数字

如果你想知道别人的 ID只需将对方发给你的消息转发给这个机器人它就会显示该用户的 ID。

获取群组 ID (Group ID)

将上述机器人(如 @getmyid_bot拉进你的群组。

在群组里输入 /myid或者机器人指定的指令

机器人会返回该群组的 ID。

注意: 普通群组 ID 通常以数字开头,而**超级群组Supergroup或频道Channel**的 ID 通常以 -100 开头。

🤝 贡献

欢迎提交 Issue 和 Pull Request

git clone https://github.com/assast/outlookEmail.git
cd outlookEmail
python -m venv venv
source venv/bin/activate
pip install -r requirements.txt
python web_outlook_app.py

📄 许可证

MIT License - 详见 LICENSE

🙏 致谢

本项目已在 LINUX DO 社区 发布,感谢社区的支持与反馈。

Star History

Star History Chart


如果这个项目对你有帮助,请给个 Star 支持一下!你的 Star 是我持续更新的动力!

初次维护一个项目2026年04月11日15:45:33才发现有几个pull没合并非常抱歉这是我的联系方式如果我没看到的话可以提醒我一下有好的建议也可以提感谢~ 邮箱u3794336@outlook.com

免责声明

本项目仅供学习、研究和技术交流使用,请遵守相关平台和服务条款,不要用于违规、滥用或非法用途。 因使用本项目产生的任何风险和后果,由使用者自行承担。