搭建 CloudFlare 免费收发 临时域名邮箱

优点:无需服务器,无需25端口,便于操作,可通过Telegram直接创建邮箱和收发邮件。

GitHub地址:链接

教程

使用Cloudflare免费服务搭建临时邮箱系统
项目原地址:链接
演示地址:链接
事先准备内容:

  1. 一个cloudflare账户
  2. 两个域名,分别对应
    前端: tm.b4.hk
    后端: tmapi.b4.hk

    D1数据库配置

    1.打开Cloudflare主页

    选择左边侧栏的Workers和Pages,点进去

    选择左边侧栏的D1,点进去

    创建数据库,选择仪表盘,名字填dev,然后点击创建

    选择控制台

    在命令行处输入以下指令,然后执行,出现一下提示说明已经完成(新版本可以不用命令)

    数据库初始化

    注意
    你也可以跳过初始化数据库,在部署完成后,在 admin 页面的 快速设置 -> 数据库 中,点击 初始化数据库 按钮来初始化数据库

CREATE TABLE IF NOT EXISTS raw_mails (
    id INTEGER PRIMARY KEY,
    message_id TEXT,
    source TEXT,
    address TEXT,
    raw TEXT,
    created_at DATETIME DEFAULT CURRENT_TIMESTAMP
);

CREATE INDEX IF NOT EXISTS idx_raw_mails_address ON raw_mails(address);

CREATE TABLE IF NOT EXISTS address (
    id INTEGER PRIMARY KEY,
    name TEXT UNIQUE,
    created_at DATETIME DEFAULT CURRENT_TIMESTAMP,
    updated_at DATETIME DEFAULT CURRENT_TIMESTAMP
);

CREATE INDEX IF NOT EXISTS idx_address_name ON address(name);

CREATE TABLE IF NOT EXISTS auto_reply_mails (
    id INTEGER PRIMARY KEY,
    source_prefix TEXT,
    name TEXT,
    address TEXT UNIQUE,
    subject TEXT,
    message TEXT,
    enabled INTEGER DEFAULT 1,
    created_at DATETIME DEFAULT CURRENT_TIMESTAMP
);

CREATE INDEX IF NOT EXISTS idx_auto_reply_mails_address ON auto_reply_mails(address);

CREATE TABLE IF NOT EXISTS address_sender (
    id INTEGER PRIMARY KEY,
    address TEXT UNIQUE,
    balance INTEGER DEFAULT 0,
    enabled INTEGER DEFAULT 1,
    created_at DATETIME DEFAULT CURRENT_TIMESTAMP
);

CREATE INDEX IF NOT EXISTS idx_address_sender_address ON address_sender(address);

CREATE TABLE IF NOT EXISTS sendbox (
    id INTEGER PRIMARY KEY,
    address TEXT,
    raw TEXT,
    created_at DATETIME DEFAULT CURRENT_TIMESTAMP
);

CREATE INDEX IF NOT EXISTS idx_sendbox_address ON sendbox(address);

CREATE TABLE IF NOT EXISTS settings (
    key TEXT PRIMARY KEY,
    value TEXT,
    created_at DATETIME DEFAULT CURRENT_TIMESTAMP,
    updated_at DATETIME DEFAULT CURRENT_TIMESTAMP
);

CREATE TABLE IF NOT EXISTS users (
    id INTEGER PRIMARY KEY,
    user_email TEXT UNIQUE NOT NULL,
    password TEXT NOT NULL,
    user_info TEXT,
    created_at DATETIME DEFAULT CURRENT_TIMESTAMP,
    updated_at DATETIME DEFAULT CURRENT_TIMESTAMP
);

CREATE INDEX IF NOT EXISTS idx_users_user_email ON users(user_email);

CREATE TABLE IF NOT EXISTS users_address (
    id INTEGER PRIMARY KEY,
    user_id INTEGER,
    address_id INTEGER UNIQUE,
    created_at DATETIME DEFAULT CURRENT_TIMESTAMP
);

CREATE INDEX IF NOT EXISTS idx_users_address_user_id ON users_address(user_id);

CREATE INDEX IF NOT EXISTS idx_users_address_address_id ON users_address(address_id);

CREATE TABLE IF NOT EXISTS user_roles (
    id INTEGER PRIMARY KEY,
    user_id INTEGER UNIQUE NOT NULL,
    role_text TEXT,
    created_at DATETIME DEFAULT CURRENT_TIMESTAMP,
    updated_at DATETIME DEFAULT CURRENT_TIMESTAMP
);

CREATE INDEX IF NOT EXISTS idx_user_roles_user_id ON user_roles(user_id);

指令来源:链接

至此D1数据库配置完成

后台程序部署

返回Workers和pages,选择创建

创建一个Workers,点击创建一个Workers,名字为tmapi,然后点击部署
回到 Workers & Pages,找到刚刚创建的 worker,点击 Settings -> Runtime, 修改 Compatibility flags, 手动输入增加 nodejs_compat, 兼容日期也需要大于图片中的日期。

在概述页面找到刚刚创建的Worker,点击右上角的编辑代码

点击左上角的文件夹符号,删除worker.js

下载这个文件,并且上传,再点击右上角的部署
下载


回到最开始的worker界面,点击设置,选择变量,添加以下三个变量,DOMAINS填写顶级域名,然后点击部署

ADMIN_PASSWORDS = ["1234"]
DOMAINS = ["b4.hk"]
JWT_SECRET =["xxxyyyzzz"]

往下滑动,点击下方的KV 命名空间绑定,选择创建,名称填写为temp_mail,点击添加

返回Worker,绑定刚刚的KV,变量名称为KV,命名空间为刚刚创建的,然后部署

绑定D1数据库,变量名为DB

选择触发器,添加自定义后端域(tmapi.b4.hk)

安全检查,分别访问tmapi.b4.hk和tmapi.b4.hk/health_check,返回结构为ok则代表完成

前端程序部署

返回Workers和pages点击创建,选择pages

生成配置文件,打开作者提供的地址:配置文件生成,在这里输入你的后端域名,点击生成,然后下载

返回刚刚的创建pages,选择上传资产,命名为tempmail,等待压缩包上传完成,选择部署站点

进入项目,点击自定义域,添加自己的前端域(tm.b4.hk),点击继续,然后激活域

访问前端域名,输入密码1234,可以正常进入则代表完成,管理员页面为域名/admin

邮件设置
进入到你设置的域名,选择左边侧边栏的电子邮件-->电子邮件路由

添加DNS记录

点击目标地址,验证一个邮箱地址,一般使用自己邮箱就好

点击路由规则,编辑,将操作改为发动到Worker,选择刚刚创建的后端,保存

启用这个规则

再次访问前端界面,正常访问则代表部署成功

发送邮件部署

  1. 访问注册https://resend.com
  2. 选择Domains

3.添加domain,并且验证

4.点击旁边的api,创建api密钥,选择全权限,复制密钥

5.回到cloudflare的worker和pages页面,选择后端的worker,进入项目

6.点击设置,选择变量,点击编辑变量,添加变量,部署

RESEND_TOKEN = 你的密钥

Telegram机器人部署

  1. 创建一个机器人,在tg中搜索@BotFather申请
  2. 获取到机器人的token,然后搜索@userinfobot,获取自己的账户id
  3. 仿照之前的步骤再次添加变量
TELEGRAM_BOT_TOKEN = 机器人token

打开系统的管理员页面:前端域名/admin,在此处填写你的tg用户id

至此所有基础配置完成
附:所有变量名称及作用,添加方式如之前所示

[vars]
# TITLE = "Custom Title" # 自定义网站标题
PREFIX = "tmp" # 要处理的邮箱名称前缀,不需要后缀可配置为空字符串
# 如果你想要你的网站私有,取消下面的注释,并修改密码
# PASSWORDS = ["123", "456"]
# admin 控制台密码, 不配置则不允许访问控制台
# ADMIN_PASSWORDS = ["123", "456"]
# admin 联系方式,不配置则不显示,可配置任意字符串
# ADMIN_CONTACT = "[email protected]"
DOMAINS = ["xxx.xxx1" , "xxx.xxx2"] # 你的域名, 支持多个域名
JWT_SECRET = "xxx" # 用于生成 jwt 的密钥, jwt 用于给用户登录以及鉴权
BLACK_LIST = "" # 黑名单,用于过滤发件人,逗号分隔
# 是否允许用户创建邮件, 不配置则不允许
ENABLE_USER_CREATE_EMAIL = true
# 允许用户删除邮件, 不配置则不允许
ENABLE_USER_DELETE_EMAIL = true
# 允许自动回复邮件
ENABLE_AUTO_REPLY = false
# 是否启用 webhook
# ENABLE_WEBHOOK = true
# 前端界面页脚文本
# COPYRIGHT = "Dream Hunter"
# 默认发送邮件余额,如果不设置,将为 0
# DEFAULT_SEND_BALANCE = 1
# Turnstile 人机验证配置
# CF_TURNSTILE_SITE_KEY = ""
# CF_TURNSTILE_SECRET_KEY = ""
# dkim config
# DKIM_SELECTOR = "mailchannels" # 参考 DKIM 部分 mailchannels._domainkey 的 mailchannels
# DKIM_PRIVATE_KEY = "" # 参考 DKIM 部分 priv_key.txt 的内容
# telegram bot 最多绑定邮箱数量
# TG_MAX_ACCOUNTS = 5
# 全局转发地址列表,如果不配置则不启用,启用后所有邮件都会转发到列表中的地址
# FORWARD_ADDRESS_LIST = ["[email protected]"]

文章转至Cloudflare Project