Skip to content

评论接口

评论相关的公开接口,包括获取评论列表、提交评论、评论点赞等。

获取评论列表

GET /api/comments

获取指定文章的评论列表,支持分页和嵌套结构。

  • 方法:GET
  • 路径:/api/comments
  • 鉴权:不需要

查询参数

名称位置类型必填说明
post_slugquerystring文章 slug,与前端 CWDCommentspostSlug 参数对应
siteIdquerystring站点 ID,用于多站点数据隔离,默认 default
pagequeryinteger页码,默认 1
limitqueryinteger每页数量,默认 20,最大 50
nestedquerystring是否返回嵌套结构,默认 'true'

成功响应

  • 状态码:200
json
{
  "data": [
    {
      "id": 1,
      "author": "张三",
      "email": "zhangsan@example.com",
      "url": "https://example.com",
      "contentText": "很棒的文章!",
      "contentHtml": "很棒的文章!",
      "pubDate": "2026-01-13T10:00:00Z",
      "postSlug": "/blog/hello-world",
      "avatar": "https://gravatar.com/avatar/...",
      "priority": 2,
      "likes": 5,
      "replies": [
        {
          "id": 2,
          "author": "李四",
          "email": "lisi@example.com",
          "url": null,
          "contentText": "同感!",
          "contentHtml": "同感!",
          "pubDate": "2026-01-13T11:00:00Z",
          "postSlug": "/blog/hello-world",
          "avatar": "https://gravatar.com/avatar/...",
          "parentId": 1,
          "replyToAuthor": "张三",
          "priority": 1,
          "likes": 2
        }
      ]
    }
  ],
  "pagination": {
    "page": 1,
    "limit": 20,
    "total": 1,
    "totalCount": 2
  }
}

返回字段说明:

字段名类型说明
idnumber评论 ID
authorstring评论者昵称
emailstring评论者邮箱(hash后)
urlstringnull)
contentTextstring评论内容(纯文本)
contentHtmlstring评论内容(渲染后的 HTML)
pubDatestring发布时间(ISO 8601 格式)
postSlugstring文章 slug
avatarstring头像 URL(Gravatar)
prioritynumber置顶权重,数值越大排序越靠前
likesnumber点赞数,默认为 0
repliesarray子评论列表(嵌套结构时)
parentIdnumbernull)
replyToAuthorstring(null)

说明:

  • nested=true(默认)时,接口返回的是"根评论列表",每条根评论包含其 replies
  • nested=false 时,接口返回扁平列表,所有评论都在 data 中,replies 为空。
  • priority 字段:评论的置顶权重,数值越大排序越靠前。
  • likes 字段:评论的点赞数,默认为 0。

错误响应

  • 缺少 post_slug

    • 状态码:400
    json
    {
      "message": "post_slug is required"
    }
  • 服务器内部错误:

    • 状态码:500
    json
    {
      "message": "错误信息"
    }

提交评论

POST /api/comments

提交新评论或回复。

  • 方法:POST
  • 路径:/api/comments
  • 鉴权:不需要

请求头

名称必填示例
Content-Typeapplication/json

请求头

名称必填示例
Content-Typeapplication/json
X-Site-Idblog

请求体(Request Body)

json
{
  "post_slug": "hello-world",
  "post_title": "博客标题,可选",
  "post_url": "https://example.com/blog/hello-world",
  "name": "张三",
  "email": "zhangsan@example.com",
  "url": "https://zhangsan.me",
  "content": "很棒的文章!",
  "parent_id": 1,
  "adminToken": "your-admin-key"
}

字段说明:

字段名类型必填说明
post_slugstring文章 slug,应与前端组件初始化时的 postSlug 值一致,如 hello-world
post_titlestring文章标题,用于邮件通知内容
post_urlstring文章完整 URL,用于邮件通知中的跳转链接
namestring评论者昵称
emailstring评论者邮箱,需为合法邮箱格式
urlstring评论者个人主页或站点地址
contentstring评论内容,内部会过滤 <script>...</script> 片段
parent_idnumber父评论 ID,用于回复功能;缺省或 null 表示根评论
adminTokenstring管理员评论密钥,博主发布评论时需要先通过 /api/verify-admin 验证密钥后将密钥传入此字段,评论将直接通过且不受审核设置影响

请求头说明:

名称必填说明
X-Site-Id站点 ID,用于多站点数据隔离,默认 default

成功响应

  • 状态码:200

评论直接通过时:

json
{
  "message": "评论已提交",
  "status": "approved"
}

评论进入待审核状态时(开启"先审核再显示"且非管理员评论):

json
{
  "message": "已提交评论,待管理员审核后显示",
  "status": "pending"
}

错误响应

  • 请求体缺失或字段类型错误:

    • 状态码:400
    json
    {
      "message": "无效的请求体"
    }
  • 缺少必填字段:

    • post_slug 为空:

      json
      {
        "message": "post_slug 必填"
      }
    • content 为空:

      json
      {
        "message": "评论内容不能为空"
      }
    • author 为空:

      json
      {
        "message": "昵称不能为空"
      }
    • email 为空或格式不正确:

      json
      {
        "message": "邮箱不能为空"
      }

      json
      {
        "message": "邮箱格式不正确"
      }
  • IP 或邮箱被限制:

    • IP 被限制:

      • 状态码:403
      json
      {
        "message": "当前 IP 已被限制评论,请联系站长进行处理"
      }
    • 邮箱被限制:

      • 状态码:403
      json
      {
        "message": "当前邮箱已被限制评论,请联系站长进行处理"
      }
  • 管理员评论验证失败:

    • 未输入密钥:

      • 状态码:401
      json
      {
        "message": "请输入管理员密钥",
        "requireAuth": true
      }
    • 密钥错误:

      • 状态码:401
      json
      {
        "message": "密钥错误"
      }
    • 验证失败次数过多:

      • 状态码:403
      json
      {
        "message": "验证失败次数过多,请 30 分钟后再试"
      }
  • 评论频率限制:

    • 状态码:429
    • 逻辑:同一 IP 最近一条评论时间在 10 秒内,则拒绝此次请求。
    json
    {
      "message": "评论频繁,等 10s 后再试"
    }
  • 服务器内部错误:

    • 状态码:500
    json
    {
      "message": "Internal Server Error"
    }

点赞评论

POST /api/comments/like

对指定评论进行点赞操作。

  • 方法:POST
  • 路径:/api/comments/like
  • 鉴权:不需要

请求头

名称必填示例
Content-Typeapplication/json

请求体

json
{
  "id": 123
}

字段说明:

字段名类型必填说明
idnumber评论 ID

成功响应

  • 状态码:200
json
{
  "message": "点赞成功",
  "likes": 5
}

字段说明:

字段名类型说明
likesnumber更新后的点赞数

错误响应

  • 状态码:400
json
{
  "message": "评论不存在"
}

取消点赞评论

DELETE /api/comments/like

取消对指定评论的点赞。

  • 方法:DELETE
  • 路径:/api/comments/like
  • 鉴权:不需要

请求头

名称必填示例
Content-Typeapplication/json

请求体

json
{
  "id": 123
}

字段说明:

字段名类型必填说明
idnumber评论 ID

成功响应

  • 状态码:200
json
{
  "message": "取消点赞成功",
  "likes": 4
}

字段说明:

字段名类型说明
likesnumber更新后的点赞数

错误响应

  • 状态码:400
json
{
  "message": "评论不存在"
}

基于 Cloudflare Workers 构建