Weixin APIs - Search (V1)
Supports keyword-based search for both Weixin Official Accounts and their published articles. It returns matched accounts or posts with details such as account name, article title, publish time, and summary.
Typical use cases:
- Discovering new accounts related to specific topics.
- Finding historical articles using keywords.
Parameters
| Name | In | Type | Required | Description |
|---|---|---|---|---|
token | query | string | Yes | Access token for the API. |
keyword | query | string | Yes | The search keyword. |
offset | query | integer | No | Pagination offset (starts with 0, increment by 20). |
searchType | query | string | No | Type of search results (accounts, articles, etc.). Available Values: - _0: All- _1: WeChat Official Account- _2: Article- _7: WeChat Channel- _262208: Wechat Mini Program- _384: Emoji- _16777728: Encyclopedia- _9: Live- _1024: Book- _512: Music- _16384: News- _8192: Wechat Index- _8: Moments |
sortType | query | string | No | Sorting criteria for search results. Available Values: - _0: Default- _2: Latest- _4: Hot |
Code Samples
💡 Environment Note
Default samples use https://api.justoneapi.com (prod-global). For users in Mainland China, it is recommended to replace it with http://47.117.133.51:30015 (prod-cn) for better performance. See Environment Guide.
bash
# Tip: For Mainland China, replace https://api.justoneapi.com with http://47.117.133.51:30015
curl -X GET "https://api.justoneapi.com/api/weixin/search/v1?token=YOUR_API_KEY&keyword=VALUE"text
I want to use the "Search (V1)" API from Just One API.
API Endpoint: https://api.justoneapi.com/api/weixin/search/v1
HTTP Method: GET
Authentication: Append "?token=YOUR_API_KEY" to the URL.
OpenAPI Definition: https://docs.justoneapi.com/openapi/weixin-apis/search-v1-en.json
Parameters:
- token (query): Access token for the API. (Required)
- keyword (query): The search keyword. (Required)
- offset (query): Pagination offset (starts with 0, increment by 20).
- searchType (query): Type of search results (accounts, articles, etc.).
Available Values:
- `_0`: All
- `_1`: WeChat Official Account
- `_2`: Article
- `_7`: WeChat Channel
- `_262208`: Wechat Mini Program
- `_384`: Emoji
- `_16777728`: Encyclopedia
- `_9`: Live
- `_1024`: Book
- `_512`: Music
- `_16384`: News
- `_8192`: Wechat Index
- `_8`: Moments
- sortType (query): Sorting criteria for search results.
Available Values:
- `_0`: Default
- `_2`: Latest
- `_4`: Hot
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
# Tip: For Mainland China, replace https://api.justoneapi.com with http://47.117.133.51:30015
import requests
url = "https://api.justoneapi.com/api/weixin/search/v1?token=YOUR_API_KEY&keyword=VALUE"
response = requests.get(url)
print(response.json())js
// Tip: For Mainland China, replace https://api.justoneapi.com with http://47.117.133.51:30015
const response = await fetch("https://api.justoneapi.com/api/weixin/search/v1?token=YOUR_API_KEY&keyword=VALUE", {
method: "GET"
});
const data = await response.json();
console.log(data);java
// Tip: For Mainland China, replace https://api.justoneapi.com with http://47.117.133.51:30015
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 {
HttpClient client = HttpClient.newHttpClient();
HttpRequest request = HttpRequest.newBuilder()
.uri(URI.create("https://api.justoneapi.com/api/weixin/search/v1?token=YOUR_API_KEY&keyword=VALUE"))
.method("GET", HttpRequest.BodyPublishers.noBody())
.build();
HttpResponse<String> response = client.send(request, HttpResponse.BodyHandlers.ofString());
System.out.println(response.body());
}
}go
// Tip: For Mainland China, replace https://api.justoneapi.com with http://47.117.133.51:30015
package main
import (
"fmt"
"io"
"net/http"
)
func main() {
client := &http.Client{}
url := "https://api.justoneapi.com/api/weixin/search/v1?token=YOUR_API_KEY&keyword=VALUE"
req, _ := http.NewRequest("GET", url, nil)
resp, _ := client.Do(req)
defer resp.Body.Close()
body, _ := io.ReadAll(resp.Body)
fmt.Println(string(body))
}php
// Tip: For Mainland China, replace https://api.justoneapi.com with http://47.117.133.51:30015
<?php
$ch = curl_init();
curl_setopt($ch, CURLOPT_URL, "https://api.justoneapi.com/api/weixin/search/v1?token=YOUR_API_KEY&keyword=VALUE");
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
curl_setopt($ch, CURLOPT_CUSTOMREQUEST, "GET");
$response = curl_exec($ch);
curl_close($ch);
echo $response;Responses
json
{
"code": 0,
"data": {
"boxID": "0x800-0-0",
"boxPos": 28,
"boxPosMerge": 7,
"count": 6,
"items": [
{
"docID": "附近3公里吃的美食",
"jumpType": 15,
"parentType": 20,
"reportId": "%E9%99%84%E8%BF%913%E5%85%AC%E9%87%8C%E5%90%83%E7%9A%84%E7%BE%8E%E9%A3%9F:hint:609944",
"word": "附近3公里吃的美食"
},
{
"docID": "苗嫂现状",
"jumpType": 15,
"parentType": 20,
"reportId": "%E8%8B%97%E5%AB%82%E7%8E%B0%E7%8A%B6:hint:775244",
"word": "苗嫂现状"
},
{
"docID": "深夜放毒美食诱惑",
"jumpType": 15,
"parentType": 20,
"reportId": "%E6%B7%B1%E5%A4%9C%E6%94%BE%E6%AF%92%E7%BE%8E%E9%A3%9F%E8%AF%B1%E6%83%91:hint:370654",
"word": "深夜放毒美食诱惑"
},
{
"docID": "舌尖上的美食",
"jumpType": 15,
"parentType": 20,
"reportId": "%E8%88%8C%E5%B0%96%E4%B8%8A%E7%9A%84%E7%BE%8E%E9%A3%9F:hint:529193",
"word": "舌尖上的美食"
},
{
"docID": "附近5公里的美食",
"jumpType": 15,
"parentType": 20,
"reportId": "%E9%99%84%E8%BF%915%E5%85%AC%E9%87%8C%E7%9A%84%E7%BE%8E%E9%A3%9F:hint:574669",
"word": "附近5公里的美食"
},
{
"docID": "好吃美食大全",
"jumpType": 15,
"parentType": 20,
"reportId": "%E5%A5%BD%E5%90%83%E7%BE%8E%E9%A3%9F%E5%A4%A7%E5%85%A8:hint:666575",
"word": "好吃美食大全"
}
],
"mixerCommonContext": "{\"mixerrank_list\":[],\"feedrank_list\":[],\"commentrank_list\":[]}",
"real_type": 2048,
"resultType": 0,
"subType": 0,
"title": "相关搜索",
"type": 24
}
}💡 Note: For list data, the example shows only 1-2 items for simplicity. The actual count depends on the API response.
