📊 总账号数
{{ stats.total || 0 }}
✅ 正常
{{ (stats.by_status||{})['正常'] || 0 }}
❌ 异常
{{ (stats.by_status||{})['异常'] || 0 }}
⏳ 未检测
{{ (stats.by_status||{})['未检测'] || 0 }}
📁 分组统计
{{ row.name }}
🔍
🔄 刷新
📥 批量导入
🗑️ 批量删除
📋 批量复制
⬇️ 下载账号
正常账号(排除刷新失败)
全部账号
当前分组「{{ filterGroup }}」
📁 移动分组
{{ g.name }}
正在删除...
{{ deleteProgress }} / {{ deleteTotal }}
{{ row.is_starred ? '⭐' : '☆' }}
{{ row.email }}
{{ row._showPwd ? row._pwd : '••••••' }}
{{ row.status }}
{{ row.auxiliary_email }}
未设置
{{ row.type }}
查看邮件
复制邮箱
复制要素
复制API
删除
📮
🔍 查询
📋 复制API
快捷域名:
@{{d}}
查看
域名类型
🎲 换一个
📋 复制
📧 查看邮件
点击「换一个」获取随机邮箱
📊 池总数
{{ randInfo.total || 0 }}
📦 剩余
{{ randInfo.remaining || 0 }}
⏱ 刷新倒计时
{{ randInfo.refresh_in || 0 }}s
🔹 每次调用返回不同邮箱,用完自动重新洗牌
🔹 池每 300 秒自动刷新
🔹 公开 API:GET /api/random-email?domain=outlook
✨ 生成邮箱
🌐
🔍 查询
📋 复制API
快捷域名:
@{{d}}
{{ tpCurrentEmail }}
服务:{{ tpServiceLabel }}
{{ tpExpireInfo }}
📋 复制邮箱
🔍 查邮件
历史邮箱:
{{ h.email }}
{{ row.source || '未知' }}
查看
快速导航
查询邮件
临时邮箱
三方邮箱
随机邮箱
账号管理
基础信息
Base URL https://liao.bot/email-api
认证方式 部分接口需要 Authorization: Bearer {密码}
返回格式 JSON
📬 查询最新邮件(无需认证)
通用接口,支持 Outlook / 临时邮箱 / Belekas 全域名
GET /api/first-email?femail={邮箱地址}
示例
// Outlook 账号
GET /api/first-email?femail=user@outlook.com
// 临时邮箱
GET /api/first-email?femail=abc@bwen.net
GET /api/first-email?femail=test@sub.liao.bot
// Belekas 临时邮箱(需先创建)
GET /api/first-email?femail=daalab@belekas.lt
返回
// 有邮件
{"email":"abc@bwen.net", "has_mail":true, "folder":"inbox",
"mail":{"from":"...","subject":"...","date":"...","body":"..."}}
// 无邮件
{"email":"abc@bwen.net", "has_mail":false, "message":"暂无邮件"}
📮 临时邮箱查询(需认证)
查询自建临时邮箱的所有邮件
GET /api/temp-mail?to={邮箱地址}
参数 说明
to完整临时邮箱地址,如 abc@bwen.net
支持域名
{{ d }}
支持子域名,如 abc@sub.liao.bot
查询可用域名
GET /api/temp-mail/domains
🌐 三方临时邮箱(无需认证)
集成 5 个免费三方临时邮箱服务,统一 API 调用
使用流程: ① 调用 create 创建邮箱 → ② 用返回的邮箱去注册网站 → ③ 调用 first-email 查收验证邮件
统一创建接口
GET /api/thirdparty/create?service=tempmailc&username=abc
service服务名:tempmailc / mailtm / tempyemail / mailcx / belekas(默认 tempmailc)
username可选,指定邮箱前缀
GET /api/thirdparty/services 列出所有可用服务和域名
服务 域名 特点 独立 API
TempMailC iopia.org, kvarra.org, aatrox.org, ambes.org, kojoball.email, kortazo.email 无限速,无需预创建 /api/tempmailc/create
Mail.tm web-library.net(动态) 8 QPS,最可靠 /api/mailtm/create
tempy.email getemail.live 等(动态) 10 分钟有效 /api/tempyemail/create
mail.cx ddker.com 1小时保留,无需预创建 /api/mailcx/create
Belekas.lt belekas.lt 需先创建,有 UI /api/belekas/create
// 1. 创建邮箱(任选一个服务)
GET /api/thirdparty/create?service=tempmailc
→ {"success":true, "email":"abc@iopia.org", ...}
// 2. 用返回的邮箱注册网站,等验证码邮件到达
// 3. 查邮件(所有域名统一用 first-email)
GET /api/first-email?femail=abc@iopia.org
→ {"has_mail":true, "mail":{"subject":"验证码","body":"123456"}}
// 列出所有可用服务
GET /api/thirdparty/services
🎲 随机邮箱(无需认证)
每次返回不重复的随机临时邮箱地址
GET /api/random-email?domain=liao.bot&type=subdomain
参数 说明
domain域名(默认 liao.bot)
type类型:main(主域名)/ subdomain(子域名,默认)
{"email":"john.doe@abc123.liao.bot", "domain":"liao.bot",
"type":"subdomain", "expires_in":300}
📋 账号管理(需认证)
管理 Outlook 邮箱账号,需 Authorization header
方法 端点 说明
GET /api/accounts 账号列表(分页、搜索、分组筛选)
GET /api/account/{email} 单个账号详情
POST /api/account/import 导入单个账号
POST /api/batch/import 批量导入账号
DELETE /api/account/{email} 删除账号
GET /api/emails/{email} 获取邮件列表
GET /api/stats 统计信息
GET /api/groups 分组列表
GET /api/health 健康检查(无需认证)
步骤1: 点击按钮打开微软登录页面,输入邮箱密码完成登录。
步骤2: 登录成功后,浏览器会跳转到一个空白页面,复制该页面的完整地址栏URL 粘贴到下方输入框。
系统将自动从URL中提取授权码并换取 refresh_token 和 access_token。
Secure Connection Failed — 代理SSL不兼容,换一个代理IP
Please try again (人机验证失败)— UA或IP被标记,换浏览器/代理
We can't create your account — 账号IP异常,换干净的住宅IP
空白页无code参数 — 登录未完成或被拦截,重试
Client ID(可选,默认使用内置ID)
🔑 步骤1:打开微软登录
步骤2:粘贴回调URL
换取令牌
授权结果
{{ oauthResult.email || '-' }}
{{ oauthResult.name || '-' }}
{{ oauthResult.expires_in }}s
refresh_token
复制 refresh_token
access_token
复制 access_token
四要素格式(可直接导入)
复制四要素
导入到系统
完整 JSON
复制 JSON
📊 数据库总账号
{{ refreshStatus.total || stats.total || 0 }}
✅ 上次成功
{{ refreshStatus.success || 0 }}
❌ 上次失败
{{ refreshStatus.fail || 0 }}
� 已移动
{{ refreshStatus.moved || 0 }}
天
保存
{{ refreshStatus.last_run ? new Date(refreshStatus.last_run).toLocaleString() : '从未执行' }}
{{ refreshStatus.next_run ? new Date(refreshStatus.next_run).toLocaleString() : '首次刷新后自动计算' }}
{{ refreshStatus.last_result || '-' }}
刷新中 {{ refreshStatus.progress }}% ({{ refreshStatus.current }}/{{ refreshStatus.total }})
空闲
🔄 开始刷新(失败移到「刷新失败」分组)
🔄 仅刷新(不移动失败)
📊 刷新状态
🗑️ 一键清理「刷新失败」账号
🔹 刷新所有数据库中有 refresh_token 的账号(约12000+个)
🔹 成功:自动更新新的 refresh_token 到数据库
🔹 失败(白号/锁定/过期):备份到 logs/token_backup/ 并移到「刷新失败」分组
🔹 自动刷新:每30天执行一次,防止令牌过期
🔹 预计耗时:{{ Math.ceil((refreshStatus.total || stats.total || 12000) * 0.3 / 60) }} 分钟
发送验证码
{{ verifySendResult.message || verifySendResult.error }}
批量发送
收件邮箱列表(每行一个,共识别 {{ batchParsedCount }} 个有效邮箱,{{ batchDuplicateCount }} 个重复 ,{{ batchInvalidCount }} 个无效 )
场景名称(邮件标题)
间隔(秒)
?
并发数
?
≈ {{ batchRateLabel }}
开始批量发送
取消任务
清空结果
状态:{{ batchStatusLabel }}
总数:{{ batchTask.total }}
成功:{{ batchTask.sent }}
失败:{{ batchTask.failed }}
未处理:{{ batchTask.total - batchTask.sent - batchTask.failed }}
并发:{{ batchTask.max_concurrency }}
成功
失败
发件人: {{ row.sender }}
{{ row.error }}
验证验证码
{{ verifyCheckResult.message }}
服务状态
{{ verifyStatus.accounts_available }}
可用发件账号
{{ verifyStatus.accounts_suspended }}
已挂起账号
{{ verifyStatus.stats?.sent || 0 }}
已发送
{{ verifyStatus.stats?.verified || 0 }}
已验证
邮件模板编辑
可用变量:{code}(验证码)、{scene_name}(场景名)、{expire_min}(过期分钟数)
邮件标题模板
邮件正文模板(HTML)
保存模板
预览效果
重置默认
预览标题:{{ tplPreviewSubject }}
API 接入文档
发送验证码
POST /api/verify/send-code
Body: {"email": "user@xxx.com", "scene_name": "注册验证"}
Response: {"success": true, "expire": 300}
验证验证码
POST /api/verify/verify-code
Body: {"email": "user@xxx.com", "code": "123456"}
Response: {"success": true, "message": "验证成功"}
批量发送验证码(异步)
POST /api/verify/send-batch
Body: {"emails": ["a@x.com","b@x.com"], "scene_name": "邮箱验证", "interval_sec": 1}
Response: {"success": true, "task_id": "abc123...", "total": 2}
GET /api/verify/send-batch/status/<task_id> 查进度
POST /api/verify/send-batch/cancel/<task_id> 取消任务
服务状态
GET /api/verify/status
➕ 新建分组
🔄 刷新
默认
{{ g.name }}
{{ g.count }} 个账号
查看账号
重命名
删除
⬇️ 下载
🗑 清空账号