CSDN Blog Article Publish Skills
技能概述
- 支持读取指定目录下的 Markdown 文件内容,并将其保存为 CSDN 草稿
- 生成 Markdown 文章并保存到本地文件
- 保存 Markdown 文章为 CSDN 草稿
- 支持本地前置校验,在请求发送前检查配置缺项、标题、标签数量、摘要长度、发布必填项等问题
- 自动维护本地文章映射文件
csdn_article_map.json,记录file -> articleId -> url - 根据文章 ID 或已保存过的 Markdown 文件更新文章
- 发布文章(需额外字段)
⚠️ 重要注意事项
- 防限流:CSDN 有接口限流机制,请勿频繁调用 API
- 建议操作:
- 单次保存/更新操作间隔至少 5-10 秒
- 每天保存/更新文章数量建议不超过5篇
- 批量操作时适当增加间隔时间
- 优先使用草稿状态,确认无误后再发布
使用流程
步骤 1:配置请求头
判断当前目录下是否存在 csdn_config.json 文件,若文件不存在请复制 config/config_example.json到工作目录下,并重命名为 csdn_config.json,文件需要根据示例文档让用户进行更改,填写请求头信息: config_example.json
获取请求头方法
- 登录 CSDN 并打开 https://editor.csdn.net/md/ Markdown风格的文章编辑器
- 填写标题和内容,点击保存为草稿
- 打开浏览器开发者工具(F12)
- 切换到 Network(网络)标签
- 找到
saveArticle请求,右键 → Copy → Copy as cURL - 从 curl 命令中提取以下请求头:
Cookie: 用户登录Cookiex-ca-nonce: 请求唯一标识(UUID)x-ca-signature: 签名x-ca-signature-headers: 签名头列表x-ca-key: API Key
配置文件格式
{
"headers": {
"Cookie": "用户Cookie",
"x-ca-nonce": "UUID",
"x-ca-signature": "签名",
"x-ca-signature-headers": "x-ca-key,x-ca-nonce",
"x-ca-key": "API Key"
},
"defaults": {
"readType": "public",
"type": "original",
"pubStatus": "draft",
"creation_statement": 0,
"tags": "",
"categories": ""
}
}
详细字段说明见 config_example.json
脚本会在发送请求前先做本地校验:
- 检查必需请求头是否缺失或仍是示例值
- 检查 Cookie 是否明显不完整
- 检查
x-ca-signature-headers是否包含x-ca-key,x-ca-nonce - 检查默认配置中的
readType、type、pubStatus、creation_statement是否合法
步骤 2:生成 Markdown 文章
- 根据用户需求生成文章内容(Markdown格式)
- 保存到当前工作目录的
csdnarticle/文件夹中 - 文件命名建议:
{文章标题}.md
# 确保 csdnarticle 目录存在
mkdir -p csdnarticle
步骤 3:保存草稿
将本地 Markdown 文件保存为 CSDN 草稿:
# 方式1:通过 --file 参数指定 Markdown 文件(推荐)
node {skills目录}/scripts/csdn_article.js save \
--title "Python 异步编程实战" \
--file csdnarticle/Python异步编程实战.md
# 方式2:通过 --content 参数直接传递内容
node {skills目录}/scripts/csdn_article.js save \
--title "Python 异步编程实战" \
--content "# Python 异步编程实战\n\n## 简介\n\n本文介绍Python异步编程..."
# 方式3:仅使用 --file 参数,自动提取文件名作为标题
node {skills目录}/scripts/csdn_article.js save \
--file csdnarticle/Python异步编程实战.md
参数说明:
--title: 文章标题(使用 --file 时可选,未提供则使用文件名)--content: Markdown 内容(与 --file 二选一)--file: Markdown 文件路径(与 --content 二选一,推荐使用)--config: 配置文件路径(默认: csdn_config.json)
当使用 --file 保存成功后,脚本会在当前工作目录生成 csdn_article_map.json,记录该 Markdown 文件对应的文章 ID 和 URL。原有的 --id 参数仍然保留,后续 update / publish 既可以继续显式传 --id,也可以复用该映射。
步骤 4:检查草稿
引导用户在 CSDN 编辑器中检查文章排版、格式、内容是否正确,确认无误后,进入下一步。
步骤 5:发布文章(如需发布)
使用 publish 命令,通过 --extra 参数传递发布配置:
node {skills目录}/scripts/csdn_article.js publish \
--id 159048943 \
--title "Python 异步编程实战" \
--file csdnarticle/Python异步编程实战.md \
--extra '{"tags":"python,async","readType":"public","type":"original","creation_statement":1,"description":"Python 异步编程实战发布摘要"}'
--extra 参数说明:
| 字段 | 说明 | 可选值 |
|---|---|---|
| tags | 标签(逗号分隔,最多5个) | python,async |
| readType | 可见范围 | public(默认值), private, read_need_fans, read_need_vip |
| type | 文章类型 | original(默认值), repost, translated |
| creation_statement | 创作声明 | 0=无声明(默认值), 1=部分内容由AI辅助生成, 2=内容来源网络进行整合创作, 3=个人观点,仅供参考 |
| description | 文章摘要(最大256字) | - |
详细 API 参数见 api_reference.md
本地前置校验
脚本会在发送请求前拦截以下常见问题,并给出修复建议:
- 配置缺项:缺少
Cookie、x-ca-nonce、x-ca-signature、x-ca-signature-headers、x-ca-key - 配置占位符未替换:仍保留
your_cookie_here、xxxxxx等示例值 - 标题为空:未提供
--title且文件名无法生成标题 - 标签过多:
tags超过 5 个 - 摘要过长:
description超过 256 字 - 发布缺字段:
publish模式下未提供摘要,或发布枚举值不合法 - 更新/发布找不到文章:既未传
--id,也没有可复用的本地映射
本地文章映射文件
- 文件名:
csdn_article_map.json - 生成时机:使用
save/update/publish且传入--file并成功请求后 - 用途:记录 Markdown 文件与文章 ID、文章 URL 的对应关系
- 效果:后续执行
update/publish时,如果继续使用同一个--file,可以继续显式传--id,也可以省略--id改为自动复用映射
示例:
# 首次保存,生成本地映射
node {skills目录}/scripts/csdn_article.js save \
--file csdnarticle/Python异步编程实战.md
# 之后基于同一个文件更新,既可以继续传 --id,也可以直接复用映射
node {skills目录}/scripts/csdn_article.js update \
--id 159048943 \
--file csdnarticle/Python异步编程实战.md
# 或者省略 --id,自动从本地映射读取
node {skills目录}/scripts/csdn_article.js update \
--file csdnarticle/Python异步编程实战.md
# 发布时同样既支持显式传 --id,也支持直接复用映射
node {skills目录}/scripts/csdn_article.js publish \
--id 159048943 \
--file csdnarticle/Python异步编程实战.md \
--extra '{"tags":"python,async","description":"Python 异步编程的实战经验总结","creation_statement":1}'
# 或者省略 --id,自动从本地映射读取
node {skills目录}/scripts/csdn_article.js publish \
--file csdnarticle/Python异步编程实战.md \
--extra '{"tags":"python,async","description":"Python 异步编程的实战经验总结","creation_statement":1}'
目录结构
csdn-article-publish/
├── SKILL.md # 技能说明文档
├── scripts/
│ └── csdn_article.js # Node.js 脚本(核心执行脚本)
├── config/
│ ├── config_example.json # 用户配置文件示例
│ └── user_agents.json # 随机User-Agent列表
└── references/
├── api_reference.md # CSDN API 详细文档
└── troubleshooting.md # 常见问题排查指南
运行时还会在当前工作目录生成 csdn_article_map.json,该文件不在仓库中维护。
场景样例
样例 1:生成并保存草稿
"帮我写一篇关于 Python 异步编程的文章,标题是《Python 异步编程实战》,保存到 CSDN 草稿箱"
执行流程:
- 生成文章内容(Markdown格式)
- 保存到
csdnarticle/Python异步编程实战.md - 调用
save命令:# 方式1:使用 --file 参数(推荐) node scripts/csdn_article.js save \ --title "Python 异步编程实战" \ --file csdnarticle/Python异步编程实战.md # 方式2:使用 --content 参数(内容较短时) node scripts/csdn_article.js save \ --title "Python 异步编程实战" \ --content "# Python 异步编程实战\n\n## 简介\n\n本文介绍..." - 返回文章 ID 供用户后续操作
样例 2:更新草稿
"更新我之前那篇 CSDN 草稿(ID: 159048943),把标题改成《Python 异步编程进阶》"
执行流程:
- 根据新需求更新 Markdown 内容
- 保存到
csdnarticle/Python异步编程进阶.md - 调用
update命令:# 方式1:使用 --file 参数(推荐,若已有本地映射可省略 --id) node scripts/csdn_article.js update \ --id 159048943 \ --title "Python 异步编程进阶" \ --file csdnarticle/Python异步编程进阶.md # 方式2:使用 --content 参数 node scripts/csdn_article.js update \ --id 159048943 \ --title "Python 异步编程进阶" \ --content "# Python 异步编程进阶\n\n## 新增内容..."
样例 3:发布文章
"帮我把 ID 159048943 的文章发布到 CSDN,标签是 python,async"
执行流程:
- 引导用户确认 creation_statement、readType、type 等字段
- 调用
publish命令:# 方式1:使用 --file 参数(推荐,若已有本地映射可省略 --id) node scripts/csdn_article.js publish \ --id 159048943 \ --title "Python 异步编程实战" \ --file csdnarticle/Python异步编程实战.md \ --extra '{"tags":"python,async","creation_statement":1,"readType":"public","type":"original","description":"Python 异步编程的发布版摘要"}' # 方式2:使用 --content 参数 node scripts/csdn_article.js publish \ --id 159048943 \ --title "Python 异步编程实战" \ --content "# Python 异步编程实战\n\n..." \ --extra '{"tags":"python,async","creation_statement":1,"description":"Python 异步编程的发布版摘要"}'
故障排查
常见的请求头过期、签名失效、限流、发布失败等问题,可参考 troubleshooting.md