Skip to content

统计数据

统计数据接口用于获取评论统计、域名列表等数据看板相关信息。

所有接口都需要在请求头中携带 Bearer Token。

http
Authorization: Bearer <token>

1.1 获取评论统计数据(数据看板)

GET /admin/stats/comments

用于管理后台「数据看板」展示评论整体统计、按域名统计以及最近 30 天评论趋势。

  • 方法:GET
  • 路径:/admin/stats/comments
  • 鉴权:需要(Bearer Token)

成功响应

  • 状态码:200
json
{
	"summary": {
		"total": 123,
		"approved": 100,
		"pending": 20,
		"rejected": 3
	},
	"domains": [
		{
			"domain": "example.com",
			"total": 80,
			"approved": 70,
			"pending": 8,
			"rejected": 2
		},
		{
			"domain": "blog.example.com",
			"total": 30,
			"approved": 20,
			"pending": 9,
			"rejected": 1
		}
	],
	"last7Days": [
		{
			"date": "2026-01-15",
			"total": 10
		},
		{
			"date": "2026-01-16",
			"total": 12
		}
	]
}

字段说明:

字段名类型说明
summaryobject评论整体汇总统计
summary.totalnumber评论总数
summary.approvednumber已通过评论数
summary.pendingnumber待审核评论数
summary.rejectednumber已拒绝评论数
domainsArray<DomainStat>按域名聚合的评论统计列表
domains[].domainstring解析后的域名(如 example.com
domains[].totalnumber该域名下评论总数
domains[].approvednumber该域名下已通过评论数
domains[].pendingnumber该域名下待审核评论数
domains[].rejectednumber该域名下已拒绝评论数
last7DaysArray<DailyStat>最近 30 天的每日评论数(按自然日聚合)
last7Days[].datestring (YYYY-MM-DD)日期,UTC 时间格式化后的自然日
last7Days[].totalnumber当日评论总数

错误响应

  • 状态码:500
json
{
	"message": "获取统计数据失败"
}

1.2 获取域名列表

GET /admin/stats/domains

用于管理后台获取所有已产生评论或访问记录的域名列表,用于域名筛选下拉框等场景。

  • 方法:GET
  • 路径:/admin/stats/domains
  • 鉴权:需要(Bearer Token)

成功响应

  • 状态码:200
json
{
  "domains": [
    "blog.example.com",
    "example.com",
    "www.example.com"
  ]
}

字段说明:

字段名类型说明
domainsArray<string>域名列表,按字母排序

说明:

  • 域名从评论数据和访问统计数据中提取
  • 域名自动去重并按字母顺序排序

错误响应

  • 状态码:500
json
{
  "message": "获取域名列表失败"
}

1.3 获取点赞统计数据(点赞排行榜)

GET /admin/likes/stats

用于管理后台展示按点赞数排序的页面列表,例如「点赞排行榜」。

  • 方法:GET
  • 路径:/admin/likes/stats
  • 鉴权:需要(Bearer Token)

当前实现不接收查询参数,默认返回点赞数最多的前 50 条记录。

成功响应

  • 状态码:200
json
{
  "items": [
    {
      "pageSlug": "https://example.com/blog/hello-world",
      "pageTitle": "Hello World",
      "pageUrl": "https://example.com/blog/hello-world",
      "likes": 12
    }
  ]
}

字段说明:

字段名类型说明
pageSlugstring页面唯一标识符
pageTitlestring | null页面标题
pageUrlstring | null页面 URL
likesnumber当前页面累计点赞数

错误响应

  • 状态码:500
json
{
  "message": "获取点赞统计失败"
}

1.4 获取点赞记录列表

GET /admin/likes/list

用于管理后台查看单条点赞记录列表,支持按页面、用户以及时间范围筛选。

  • 方法:GET
  • 路径:/admin/likes/list
  • 鉴权:需要(Bearer Token)

查询参数

名称位置类型必填说明
pagequeryinteger页码,默认 1
page_slugquerystring按页面标识筛选点赞记录
user_idquerystring按用户标识筛选点赞记录,对应前端的 X-CWD-Like-User
startquerynumber起始时间(毫秒时间戳),大于等于该时间的记录
endquerynumber结束时间(毫秒时间戳),小于等于该时间的记录

说明:

  • 当前实现中每页固定大小为 20
  • 既可以使用 page_slug / user_id,也可以同时使用两者进行组合筛选。

成功响应

  • 状态码:200
json
{
  "data": [
    {
      "id": 1,
      "pageSlug": "https://example.com/blog/hello-world",
      "userId": "550e8400-e29b-41d4-a716-446655440000",
      "createdAt": 1737593600000
    }
  ],
  "pagination": {
    "page": 1,
    "limit": 20,
    "total": 3
  }
}

字段说明:

字段名类型说明
data[].idnumber点赞记录 ID
data[].pageSlugstring页面唯一标识符
data[].userIdstring用户标识(来自 X-CWD-Like-User 或 IP)
data[].createdAtnumber点赞时间戳(毫秒)
pagination.pagenumber当前页码
pagination.limitnumber每页数量(固定为 20)
pagination.totalnumber总页数

错误响应

  • 状态码:500
json
{
  "message": "获取点赞记录失败"
}

基于 Cloudflare Workers 构建