Skip to content

Xiaohongshu (RedNote) Hot Search API (V1)

GET
/api/xiaohongshu/hot-search/v1
API health status
Healthy Available Limited Mostly unavailable No data
Loading health status...

Get Xiaohongshu (RedNote) hot Search data, including popular notes and engagement metrics, for content trend discovery.

Parameters

NameInTypeRequiredDefaultDescription
tokenquerystringYes-Access token for this API service.
searchWordquerystringNo``Search keyword.
pageNumqueryintegerNo1Page number for pagination.
orderByquerystringNopremium_imp_numSort metric for the result set.

Available Values:
- premium_imp_num: Exposure
- premium_good_read_rate: Read rate
- premium_read_num: Read count
- premium_engage_num: Engagement count
- premium_engage_rate: Engagement rate
- premium_like_num: Like count
- premium_fav_num: Favorite count
- premium_cmt_num: Comment count
ndquerystringNoDAY_7Time range in days.

Available Values:
- DAY_3: Last 3 days
- DAY_7: Last 7 days
- DAY_14: Last 14 days
- DAY_30: Last 30 days

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/xiaohongshu/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/xiaohongshu/hot-search/v1?token=YOUR_API_KEY
API Endpoint: BASE_URL + /api/xiaohongshu/hot-search/v1?token=YOUR_API_KEY
HTTP Method: GET
Authentication: Append "?token=YOUR_API_KEY" to the URL.
OpenAPI Definition: https://docs.justoneapi.com/openapi/xiaohongshu-rednote/hot-search-v1-en.json

Parameters:
- token (query): Access token for this API service. (Required)
- searchWord (query): Search keyword.
- pageNum (query): Page number for pagination.
- orderBy (query): Sort metric for the result set.

Available Values:
- `premium_imp_num`: Exposure
- `premium_good_read_rate`: Read rate
- `premium_read_num`: Read count
- `premium_engage_num`: Engagement count
- `premium_engage_rate`: Engagement rate
- `premium_like_num`: Like count
- `premium_fav_num`: Favorite count
- `premium_cmt_num`: Comment count
- nd (query): Time range in days.

Available Values:
- `DAY_3`: Last 3 days
- `DAY_7`: Last 7 days
- `DAY_14`: Last 14 days
- `DAY_30`: Last 30 days

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 request timeout to at least 60 seconds.
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

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/xiaohongshu/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/xiaohongshu/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/xiaohongshu/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/xiaohongshu/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/xiaohongshu/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...