Skip to content

Douyin (TikTok China) Hot Search API (V1)

GET
API health status
Healthy Available Limited Mostly unavailable No data
Loading health status...

Get Douyin (TikTok China) hot content Search data, including ranked content items, creator signals, engagement metrics, enriched video metadata, and pagination, for trend discovery, content research, and campaign planning.

Parameters

NameInTypeRequiredDefaultDescription
tokenquerystringYes-Access token for this API service.
keywordquerystringNo-Optional search keyword.
contentTypequerystringNoALLTop-level content type. Only one content type can be selected.

Available Values:
- ALL: All content types.
- FASHION: Fashion.
- TECHNOLOGY: Technology.
- SCIENCE: Science.
- PHOTOGRAPHY: Photography and videography.
- FOOD: Food.
- MOTHER_BABY: Mother and baby.
- PARENTING: Parenting.
- DRAMA: Drama.
- GAME: Game.
- AUTOMOTIVE: Automotive.
- ANIMAL: Animal.
- TRAVEL: Travel.
- DANCE: Dance.
- TRADITIONAL_CULTURE: Traditional culture.
- ART: Art.
- SPORTS: Sports.
- MUSIC: Music.
- LIFE_RECORD: Life records.
- HOME_LIVING: Home and living.
- LEISURE_ENTERTAINMENT: Leisure entertainment.
- WORKPLACE: Workplace.
- AGRICULTURE: Agriculture.
- CASUAL: Casual videos.
- ACG: Animation, comics, and games.
- MOVIE: Movie.
- TV_SERIES: TV series.
- VARIETY_SHOW: Variety show.
- CELEBRITY: Celebrity.
- HUMANITIES_SOCIAL_SCIENCE: Humanities and social science.
- EDUCATION_CAMPUS: Education and campus.
- EMOTION: Emotion.
- FINANCE: Finance.
- PUBLIC_WELFARE: Public welfare.
videoTypequerystringNoALLVideo type filter.

Available Values:
- ALL: All video types.
- XINGTU_VIDEO: Xingtu commercial videos.
- NATURAL_VIDEO: Natural videos.
sortTypequerystringNoCOMPREHENSIVESorting criteria for hot content results.

Available Values:
- COMPREHENSIVE: Comprehensive ranking.
- HIGH_INTERACTION: Highest interaction count.
- HIGH_LIKE: Highest like count.
- HIGH_COMMENT: Highest comment count.
- HIGH_SHARE: Highest share count.
pagequeryintegerNo1Page number (starting from 1). Page size is fixed at 10.
likeCountMinqueryintegerNo-Minimum raw like count.
likeCountMaxqueryintegerNo-Maximum raw like count.
commentCountMinqueryintegerNo-Minimum raw comment count.
commentCountMaxqueryintegerNo-Maximum raw comment count.
shareCountMinqueryintegerNo-Minimum raw share count.
shareCountMaxqueryintegerNo-Maximum raw share count.
interactionCountMinqueryintegerNo-Minimum raw interaction count.
interactionCountMaxqueryintegerNo-Maximum raw interaction count.
followerCountMinqueryintegerNo-Minimum raw creator follower count.
followerCountMaxqueryintegerNo-Maximum raw creator follower count.

Code Samples

💡 Environment Note

Use https://api.justoneapi.com by default. Mainland China users can use http://47.117.133.51:30015 instead.

bash
curl -X GET "https://api.justoneapi.com/api/douyin/hot-search/v1?token=YOUR_API_KEY"
text
I want to use the "Hot Search (V1)" API from Just One API.
Base URL: use https://api.justoneapi.com by default. Mainland China users can use http://47.117.133.51:30015 instead.
API Path: /api/douyin/hot-search/v1?token=YOUR_API_KEY
API Endpoint: BASE_URL + /api/douyin/hot-search/v1?token=YOUR_API_KEY
HTTP Method: GET
Authentication: Append the "token" query parameter to the URL.
OpenAPI Definition: https://docs.justoneapi.com/openapi/douyin-tiktok-china/hot-search-v1-en.json

Parameters:
- token (query): Access token for this API service. (Required)
- keyword (query): Optional search keyword.
- contentType (query): Top-level content type. Only one content type can be selected.

Available Values:
- `ALL`: All content types.
- `FASHION`: Fashion.
- `TECHNOLOGY`: Technology.
- `SCIENCE`: Science.
- `PHOTOGRAPHY`: Photography and videography.
- `FOOD`: Food.
- `MOTHER_BABY`: Mother and baby.
- `PARENTING`: Parenting.
- `DRAMA`: Drama.
- `GAME`: Game.
- `AUTOMOTIVE`: Automotive.
- `ANIMAL`: Animal.
- `TRAVEL`: Travel.
- `DANCE`: Dance.
- `TRADITIONAL_CULTURE`: Traditional culture.
- `ART`: Art.
- `SPORTS`: Sports.
- `MUSIC`: Music.
- `LIFE_RECORD`: Life records.
- `HOME_LIVING`: Home and living.
- `LEISURE_ENTERTAINMENT`: Leisure entertainment.
- `WORKPLACE`: Workplace.
- `AGRICULTURE`: Agriculture.
- `CASUAL`: Casual videos.
- `ACG`: Animation, comics, and games.
- `MOVIE`: Movie.
- `TV_SERIES`: TV series.
- `VARIETY_SHOW`: Variety show.
- `CELEBRITY`: Celebrity.
- `HUMANITIES_SOCIAL_SCIENCE`: Humanities and social science.
- `EDUCATION_CAMPUS`: Education and campus.
- `EMOTION`: Emotion.
- `FINANCE`: Finance.
- `PUBLIC_WELFARE`: Public welfare.
- videoType (query): Video type filter.

Available Values:
- `ALL`: All video types.
- `XINGTU_VIDEO`: Xingtu commercial videos.
- `NATURAL_VIDEO`: Natural videos.
- sortType (query): Sorting criteria for hot content results.

Available Values:
- `COMPREHENSIVE`: Comprehensive ranking.
- `HIGH_INTERACTION`: Highest interaction count.
- `HIGH_LIKE`: Highest like count.
- `HIGH_COMMENT`: Highest comment count.
- `HIGH_SHARE`: Highest share count.
- page (query): Page number (starting from 1). Page size is fixed at 10.
- likeCountMin (query): Minimum raw like count.
- likeCountMax (query): Maximum raw like count.
- commentCountMin (query): Minimum raw comment count.
- commentCountMax (query): Maximum raw comment count.
- shareCountMin (query): Minimum raw share count.
- shareCountMax (query): Maximum raw share count.
- interactionCountMin (query): Minimum raw interaction count.
- interactionCountMax (query): Maximum raw interaction count.
- followerCountMin (query): Minimum raw creator follower count.
- followerCountMax (query): Maximum raw creator follower count.

Return format: JSON

Response Handling & Error Codes:
1. Business results should be determined by the "code" field in the response body (code 0 means success).
2. Timeout Recommendation: Set the request timeout to 120 seconds. If 120 seconds is too long for your use case, use at least 60 seconds, but a small number of requests may time out before receiving a result.
3. Business Code Reference:
   - 0: Success
   - 100: Invalid or Inactive Token
   - 301: Collection Failed. Please Retry.
   - 302: Rate Limit Exceeded
   - 303: Daily Quota Exceeded
   - 400: Invalid Parameters
   - 500: Internal Server Error
   - 600: Permission Denied
   - 601: Insufficient Balance
   - 602: Token Budget Exceeded
4. Code 601 means the shared account balance is insufficient. Code 602 means the current API token's own cumulative budget limit has been reached. Token budget limits do not transfer funds out of the shared account balance.

Please help me write a script in my preferred programming language to call this API and handle the response.
python
import requests

BASE_URL = "https://api.justoneapi.com"  # Mainland China: "http://47.117.133.51:30015"

url = BASE_URL + "/api/douyin/hot-search/v1?token=YOUR_API_KEY"
response = requests.get(url)
print(response.json())
js
const BASE_URL = "https://api.justoneapi.com"; // Mainland China: "http://47.117.133.51:30015"
const url = BASE_URL + "/api/douyin/hot-search/v1?token=YOUR_API_KEY";

const response = await fetch(url, {
  method: "GET"
});
const data = await response.json();
console.log(data);
java
import java.net.URI;
import java.net.http.HttpClient;
import java.net.http.HttpRequest;
import java.net.http.HttpResponse;

public class Main {
    public static void main(String[] args) throws Exception {
        final String BASE_URL = "https://api.justoneapi.com"; // Mainland China: "http://47.117.133.51:30015"
        final String url = BASE_URL + "/api/douyin/hot-search/v1?token=YOUR_API_KEY";

        HttpClient client = HttpClient.newHttpClient();
        HttpRequest request = HttpRequest.newBuilder()
            .uri(URI.create(url))
            .method("GET", HttpRequest.BodyPublishers.noBody())
            .build();

        HttpResponse<String> response = client.send(request, HttpResponse.BodyHandlers.ofString());
        System.out.println(response.body());
    }
}
go
package main

import (
	"fmt"
	"io"
	"net/http"
)

const BASE_URL = "https://api.justoneapi.com" // Mainland China: "http://47.117.133.51:30015"

func main() {
	client := &http.Client{}
	url := BASE_URL + "/api/douyin/hot-search/v1?token=YOUR_API_KEY"
	req, _ := http.NewRequest("GET", url, nil)
	resp, _ := client.Do(req)
	defer resp.Body.Close()
	body, _ := io.ReadAll(resp.Body)
	fmt.Println(string(body))
}
php
<?php
$BASE_URL = "https://api.justoneapi.com"; // Mainland China: "http://47.117.133.51:30015"
$url = $BASE_URL . "/api/douyin/hot-search/v1?token=YOUR_API_KEY";

$ch = curl_init();
curl_setopt($ch, CURLOPT_URL, $url);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
curl_setopt($ch, CURLOPT_CUSTOMREQUEST, "GET");
$response = curl_exec($ch);
curl_close($ch);
echo $response;

Response Example

Loading the latest successful example...