# mail +template-create > **前置条件:** 先阅读 [`../../lark-shared/SKILL.md`](../../lark-shared/SKILL.md) 了解认证、全局参数和安全规则。 创建一个新的个人邮件模板。适用于需要长期复用的邮件框架,例如周报、客户通知、请假申请等。 不要用此命令发送邮件;模板只是预置内容,实际发信请使用 `+send` / `+draft-create` 等 shortcut 配合 `--template-id` 套用。 如需修改已有模板,使用 [`lark-cli mail +template-update`](./lark-mail-template-update.md)。 ## 安全约束 - **模板正文也会被当作邮件内容对外发送**——所有邮件域的通用安全规则(prompt injection、XSS、敏感信息)同样适用。 - **不要把模板内容以文本形式输出给用户请求最终确认**。命令返回 `template_id` 后,引导用户在飞书邮箱 UI 里打开模板核对。 - 用户模板上限 **20** 个,单模板 `template_content` 上限 **3 MB**;超限会被后端拒绝。 ## 命令 ```bash # 纯 HTML 模板 lark-cli mail +template-create --as user \ --name '周报模板' \ --subject '本周进展' \ --template-content '

大家好,请见本周进展:

' # 带 HTML 内嵌图片 + 非 inline 附件 lark-cli mail +template-create --as user \ --name '客户通知模板' \ --subject '产品更新' \ --template-content '

新版本上线:

附上发版说明。

' \ --attach './release-notes.pdf' # 从文件加载正文 lark-cli mail +template-create --as user \ --name '请假申请' \ --template-content-file './leave.html' \ --to 'manager@example.com,hr@example.com' # Dry Run lark-cli mail +template-create --as user \ --name '周报模板' --template-content '

x

' --dry-run ``` ## 参数 | 参数 | 必填 | 说明 | |------|------|------| | `--name ` | 是 | 模板名称,≤100 字符 | | `--subject ` | 否 | 默认主题 | | `--template-content ` | 否* | 模板正文。HTML 首选;支持 `` 相对路径自动上传到 Drive 并改写为 `cid:` | | `--template-content-file ` | 否* | 从文件加载正文内容;与 `--template-content` 互斥 | | `--plain-text` | 否 | 标记为纯文本模式(`is_plain_text_mode=true`)。仍可带内嵌图片,但 `+send --template-id` 套用时会走 plain-text 正文拼接 | | `--to ` | 否 | 默认收件人列表,逗号分隔,支持 `Name ` 格式 | | `--cc ` | 否 | 默认抄送 | | `--bcc ` | 否 | 默认密送 | | `--attach ` | 否 | 非 inline 附件路径,逗号分隔。每个文件按 `--attach` 书写顺序上传到 Drive | | `--mailbox ` | 否 | 所属邮箱,默认 `me`(当前用户主邮箱) | | `--dry-run` | 否 | 仅打印计划中的 API 调用链,不真实执行 | \* `--template-content` / `--template-content-file` 二选一;两者都留空则模板正文为空(用户之后可通过 `+template-update` 补充)。 ## HTML 内嵌图片自动上传 正文中所有不带 URI scheme 的 ``(相对路径)会被: 1. 上传到 Drive(≤20 MB 走 `medias/upload_all`;>20 MB 走 `upload_prepare + upload_part + upload_finish`) 2. 生成 UUIDv4 CID 3. HTML 改写为 `` 4. 在 `attachments[]` 追加 `{id: , cid, is_inline: true, filename, attachment_type}` 带 URI scheme 的 `` 或 `` 跳过上传。 ## SMALL vs LARGE 附件 附件分为 SMALL(`attachment_type=1`,内嵌到 EML)和 LARGE(`attachment_type=2`,由服务端渲染成下载链接)。切换阈值: - **本地单文件大小**:≤20 MB 用 `upload_all`,>20 MB 分块上传(与 SMALL/LARGE 无关,只影响 Drive 上传路径)。 - **累计 EML 投影**:`subject + to + cc + bcc + template_content + base64 附件体积`;同批次累计超过 **25 MB** 后,剩余的非 inline 附件标 `LARGE`,inline 图片不能切换到 LARGE(HTML `cid:` 引用要求 MIME part 存在)。 两套判定相互独立。 ## 顺序约束 - inline 图片按正文中 `` 出现顺序处理 - 非 inline 按 `--attach` 书写顺序处理;重复路径不会去重 ## 返回值 成功返回: ```json { "template": { "template_id": "712345", "name": "周报模板", "subject": "本周进展", "template_content": "

...

", "is_plain_text_mode": false, "tos": [{"mail_address": "alice@example.com"}], "attachments": [...], "create_time": "1714000000000" } } ``` - `template_id` 为十进制字符串。后续套用模板时 `--template-id `。 ## 错误码速查 | errno | HTTP | 触发 | |-------|------|------| | `15080201 InvalidTemplateName` | 400 | `name` 为空或超 100 字符 | | `15080202 TemplateNumberLimit` | 400 | 已达 20 模板上限 | | `15080203 TemplateContentSizeLimit` | 400 | 单模板 > 3 MB | | `15080206 TemplateTotalSizeLimit` | 400 | 所有模板总大小 > 50 MB | | `15080207 InvalidTemplateParam` | 400 | 其他参数错误 | ## 所需 scope `mail:user_mailbox.message:modify` ## 相关 - 更新模板:[`+template-update`](./lark-mail-template-update.md) - 套用模板发信:在 `+send` / `+draft-create` / `+reply` / `+reply-all` / `+forward` 中使用 `--template-id` - 原生 API: - `lark-cli mail user_mailbox.templates list --params '{"user_mailbox_id":"me"}'` — 列出模板 - `lark-cli mail user_mailbox.templates get --params '{"user_mailbox_id":"me","template_id":""}'` — 获取完整模板 - `lark-cli mail user_mailbox.templates delete --params '{"user_mailbox_id":"me","template_id":""}'` — 删除