TikTok Channel Posts API
Bulk-list TikTok content with full metadata for each item.
GET request to /v1/tiktok/channel-posts that responds with clean JSON, costs 14 credits, and is cached for 24 hours (repeat calls are free). Start with 100 free credits — no credit card.What is the TikTok Channel Posts API?
The TikTok Channel Posts API lets you list items in bulk with metadata from TikTok with a single REST call. No OAuth, no scraping infrastructure, and no platform SDKs — send the URL, get clean structured JSON back. Results are cached for 24 hours, so repeat lookups are instant and free.
What you get
- Bulk list of items with full metadata
- View counts, dates, and direct URLs
- Configurable result limit
- Ideal for monitoring and content pipelines
Try it
Fill in the parameters below and copy a ready-to-run request in your language of choice.
Parameters
curl "https://api.captapi.com/v1/tiktok/channel-posts?url=https%3A%2F%2Fwww.tiktok.com%2F%40khaby.lame" \
-H "Authorization: Bearer capt_live_..."Edit the parameters and the code updates instantly. Switch languages and hit copy.
Example response
{
"success": true,
"cached": false,
"creditsUsed": 14,
"data": {
"url": "https://www.tiktok.com/@khaby.lame",
"totalReturned": 5,
"posts": [
{
"platform": "tiktok",
"url": "https://www.tiktok.com/@khaby.lame/video/7646812028874673439",
"id": "7646812028874673439",
"caption": "Thank you, please come again!!!🙋🏿♂️💸#learnfromkhaby #comedy",
"description": "Thank you, please come again!!!🙋🏿♂️💸#learnfromkhaby #comedy",
"publishedAt": "2026-06-02T14:56:35.000Z",
"durationSeconds": 29,
"thumbnailUrl": null,
"videoUrl": null,
"author": {
"username": "khaby.lame",
"displayName": "Khabane lame",
"url": "https://www.tiktok.com/@khaby.lame",
"followers": 161800000,
"verified": true,
"profileImage": "https://p16-common-sign.tiktokcdn-eu.com/tos-maliva-avt-0068/08987e23b94057953fd4f1738694bf5f~tplv-tiktokx-cropcenter:720:720.jpeg?dr=10399&refresh_token=efea3a78&x-expires=1780686000&x-signature=HpMjICg3bbESeQ%2BKMSFgXc78D0A%3D&t=4d5b0474&ps=13740610&shp=a5d48078&shcp=f20df69d&idc=no1a"
},
"engagement": {
"views": 2600000,
"likes": 276100,
"comments": 4196,
"shares": 3141,
"saves": null
},
"hashtags": [
"learnfromkhaby",
"comedy"
],
"musicName": "original sound"
},
{
"platform": "tiktok",
"url": "https://www.tiktok.com/@khaby.lame/video/7645330241254133022",
"id": "7645330241254133022",
"caption": "Did you catch me at the roadshow? It’s that simple. 👌🏻 @Experience Macao \n\n#macao #experiencemacao #madridroadshow #macaotravel",
"description": "Did you catch me at the roadshow? It’s that simple. 👌🏻 @Experience Macao \n\n#macao #experiencemacao #madridroadshow #macaotravel",
"publishedAt": "2026-05-29T15:06:21.000Z",
"durationSeconds": 26,
"thumbnailUrl": null,
"videoUrl": null,
"author": {
"username": "khaby.lame",
"displayName": "Khabane lame",
"url": "https://www.tiktok.com/@khaby.lame",
"followers": 161800000,
"verified": true,
"profileImage": "https://p16-common-sign.tiktokcdn-eu.com/tos-maliva-avt-0068/08987e23b94057953fd4f1738694bf5f~tplv-tiktokx-cropcenter:720:720.jpeg?dr=10399&refresh_token=efea3a78&x-expires=1780686000&x-signature=HpMjICg3bbESeQ%2BKMSFgXc78D0A%3D&t=4d5b0474&ps=13740610&shp=a5d48078&shcp=f20df69d&idc=no1a"
},
"engagement": {
"views": 10500000,
"likes": 154200,
"comments": 4038,
"shares": 1433,
"saves": null
},
"hashtags": [
"",
"macao"
],
"musicName": "original sound"
}
]
}
}Response structure
A successful call returns success, cached, creditsUsed, and a data object with the following fields:
Result
totalNumber of items returned.
Each item
Each item in items contains:
titleItem title.urlDirect URL to the content.viewsView count.publishedAtPublish date (ISO 8601).
Parameters
| Name | Type | Required | Description |
|---|---|---|---|
| url | string | Yes | TikTok profile URL, e.g. https://tiktok.com/@username. |
| limit | integer | No | Max items to return (default 20, max 200). Billed per result. |
Authentication: send your key as Authorization: Bearer capt_live_.... A typical call costs 14 credits — billed per result, so the exact amount scales with how many items you request. Repeat calls for the same request are served from cache for free (metrics refresh within ~1 hour).
How it works
- 1. Sign up — get 100 free credits, no card required.
- 2. Create a key from your dashboard.
- 3. Send one request to
/v1/tiktok/channel-postsand parse the JSON response.
Use cases
Content Pipelines
Ingest a channel's catalog in bulk.
Monitoring
Detect new uploads automatically.
Archiving
Snapshot a creator's full library.
Analytics
Aggregate performance across many videos.
Frequently asked questions
What does the TikTok Channel Posts API do?+
The TikTok Channel Posts API lets you list items in bulk with metadata from a public TikTok video using one GET request to /v1/tiktok/channel-posts. It returns clean JSON — no OAuth or scraping setup required.
How many credits does the TikTok Channel Posts API cost?+
Each successful call costs 14 credits. Responses are cached for 24 hours, and cached results cost 0 credits. Failed or empty results are never charged.
Do I need a TikTok API key or OAuth?+
No. A single Captapi key works across YouTube, TikTok, Instagram, and Facebook. We handle proxies, rate limits, retries, and authentication for you.
Is the TikTok Channel Posts API suitable for production use?+
Yes. It is a stable REST endpoint with predictable JSON, automatic retries, and a shared 24-hour cache. Use it for RAG pipelines, analytics, monitoring, and content automation.
More TikTok APIs
Ready to use the TikTok Channel Posts API?
Sign up, grab your key, and make your first call in 60 seconds.