Install
openclaw skills install magicx-wechat-publisher将已完成的文章发布到微信公众号草稿箱。只负责排版转换、图片上传、草稿提交,不负责文章内容生成。当用户要求"发公众号""上传草稿箱""发布文章到公众号"时触发此技能。
openclaw skills install magicx-wechat-publisher从 scripts/.wechat-config.json 读取 appid 和 secret,然后调用微信API:
curl "https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid={APPID}&secret={SECRET}"
返回 access_token,后续步骤都需要用到。
此步骤由 Agent 通过 curl 调用微信API完成,不通过脚本。
POST https://api.weixin.qq.com/cgi-bin/media/uploadimg?access_token={TOKEN}(multipart/form-data 上传,返回微信图床URL)POST https://api.weixin.qq.com/cgi-bin/material/add_material?type=image&access_token={TOKEN}(返回 media_id)将文章内容转为公众号专用HTML,必须遵守排版规范(见下方)。关键要求:
<style> 标签或 CSS class将转换好的HTML保存为文件,使用附带脚本上传到草稿箱:
node scripts/upload-draft.js --html <html文件> --title <标题> [--author <作者>]
脚本会自动:
scripts/.wechat-config.json 读取 AppID/SecretPOST /cgi-bin/draft/add 将HTML内容提交到草稿箱上传成功后通知用户去公众号后台 → 内容与互动 → 草稿箱 中检查并设置封面图,确认后发布。
<style> 标签和 CSS class<h1> 标题(标题由公众号自动显示),开头用摘要引导块代替| 元素 | 标签 | 内联样式 |
|---|---|---|
| 摘要块 | <section> | margin:10px 0 15px;padding:15px 20px;background:#f7f8fa;border-left:4px solid #0EA5E9;font-size:15px;color:#555;line-height:1.6; |
| 正文段落 | <p> | margin:3px 0;font-size:16px;line-height:1.75;color:#333; |
| 加粗 | <strong> | 不加额外样式(禁止用 <span> 或 class 模拟加粗) |
| 关键词高亮 | <strong><span> | 加粗+颜色双重强调,用于核心观点/关键数据/金句 |
纯加粗在黑字中不够突出,必须对关键词/关键句加颜色,帮助读者快速扫到重点。
| 用途 | 颜色 | 写法 |
|---|---|---|
| 核心观点/金句 | 品牌蓝 #0EA5E9 | <strong style="color:#0EA5E9;">关键句</strong> |
| 重要数据/数字 | 橙色 #f59e0b | <strong style="color:#f59e0b;">40%</strong> |
| 警示/冲突 | 红色 #ef4444 | <strong style="color:#ef4444;">警示内容</strong> |
| 正面/增长 | 绿色 #10b981 | <strong style="color:#10b981;">增长数据</strong> |
| 普通加粗 | 默认黑色 | <strong>普通强调</strong> |
<strong>,颜色只给最关键的内容
| 二级标题 | <h2> | font-size:20px;font-weight:bold;color:#111;margin-top:15px;margin-bottom:5px;padding-left:12px;border-left:4px solid #0EA5E9; |
| 三级标题 | <h3> | font-size:17px;font-weight:bold;color:#222;margin-top:12px;margin-bottom:3px; |
| 分割线 | <hr> | border:none;border-top:1px solid #eee;margin:8px 0;(禁止用 div 模拟) |
| 引用块 | <blockquote> | margin:3px 0;padding:12px 18px;background:#f7f8fa;border-left:4px solid #0EA5E9;color:#555;font-style:italic; |
| 图片容器 | <p> | text-align:center;margin:3px 0; |
| 图片 | <img> | max-width:100%;display:block;margin:0 auto;border-radius:12px; |
| 落款 | <p> | margin-top:20px;padding-top:10px;border-top:1px solid #eee;font-size:14px;color:#999;text-align:center;line-height:2; |<p style="margin-top:20px;padding-top:10px;border-top:1px solid #eee;font-size:14px;color:#999;text-align:center;line-height:2;">有用AI — 有用才会用,会用才有用。<br/>AI领域连续创业者、落地实战派<br/>亲手打造AI产品,服务数百家中大型名企</p>
<style> 标签或 CSS class<h1>(标题由公众号系统渲染)<span class="bold"> 模拟加粗(必须用 <strong>)<div> 模拟分割线(必须用 <hr>)参考 assets/article-template.html,标准结构为:
摘要引导块(section)
正文段落...
图片(推文截图等)
引用块
正文段落...
分割线
二级标题 + 图片 + 正文段落...
分割线
二级标题 + 图片 + 正文段落...
...(重复章节)
分割线
二级标题"写在最后" + 结尾段落...
落款
scripts/upload-draft.js — 草稿上传脚本(Node.js),负责调用微信API提交草稿node scripts/upload-draft.js --html <html文件> --title <标题> [--author <作者>]scripts/.wechat-config.json(本地文件,请勿提交到版本控制)node scripts/upload-draft.js --appid xxx --secret xxx --save-config本技能由 magicx 开发维护。