Skip to content

Amazon Product Search API (V1)

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

Search Amazon product listings by keyword or ASIN, including title, price, rating, Prime signals, product photos, delivery details, and pagination metadata for discovery, catalog enrichment, market research, price monitoring, and competitor analysis.

Parameters

NameInTypeRequiredDefaultDescription
tokenquerystringYes-Authentication token for this API service.
keywordquerystringYes-Search keyword or ASIN to find Amazon products.
countryquerystringNoUSCountry code for the Amazon marketplace.

Available Values:
- US: United States
- AU: Australia
- BR: Brazil
- CA: Canada
- CN: China
- FR: France
- DE: Germany
- IN: India
- IT: Italy
- MX: Mexico
- NL: Netherlands
- SG: Singapore
- ES: Spain
- TR: Turkey
- AE: United Arab Emirates
- GB: United Kingdom
- JP: Japan
- SA: Saudi Arabia
- PL: Poland
- SE: Sweden
- BE: Belgium
- EG: Egypt
- ZA: South Africa
- IE: Ireland
sortByquerystringNoRELEVANCESort order for Amazon product search results.

Available Values:
- RELEVANCE: Relevance
- LOWEST_PRICE: Lowest Price
- HIGHEST_PRICE: Highest Price
- REVIEWS: Reviews
- NEWEST: Newest
- BEST_SELLERS: Best Sellers
productConditionquerystringNoALLProduct condition filter for Amazon search results.

Available Values:
- ALL: All product conditions
- NEW: New products
- USED: Used products
- RENEWED: Renewed products
- COLLECTIBLE: Collectible products
isPrimequerybooleanNofalseWhether to return only Prime-eligible products.
dealsAndDiscountsquerystringNoNONEDeals and discounts filter for Amazon search results.

Available Values:
- NONE: Do not filter by deals or discounts
- ALL_DISCOUNTS: Return discounted products
- TODAYS_DEALS: Return today's deals
pagequeryintegerNo1Page number for pagination.

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/amazon/search-products/v1?token=YOUR_API_KEY&keyword=VALUE"
text
I want to use the "Product 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/amazon/search-products/v1?token=YOUR_API_KEY&keyword=VALUE
API Endpoint: BASE_URL + /api/amazon/search-products/v1?token=YOUR_API_KEY&keyword=VALUE
HTTP Method: GET
Authentication: Append "?token=YOUR_API_KEY" to the URL.
OpenAPI Definition: https://docs.justoneapi.com/openapi/amazon/product-search-v1-en.json

Parameters:
- token (query): Authentication token for this API service. (Required)
- keyword (query): Search keyword or ASIN to find Amazon products. (Required)
- country (query): Country code for the Amazon marketplace.

Available Values:
- `US`: United States
- `AU`: Australia
- `BR`: Brazil
- `CA`: Canada
- `CN`: China
- `FR`: France
- `DE`: Germany
- `IN`: India
- `IT`: Italy
- `MX`: Mexico
- `NL`: Netherlands
- `SG`: Singapore
- `ES`: Spain
- `TR`: Turkey
- `AE`: United Arab Emirates
- `GB`: United Kingdom
- `JP`: Japan
- `SA`: Saudi Arabia
- `PL`: Poland
- `SE`: Sweden
- `BE`: Belgium
- `EG`: Egypt
- `ZA`: South Africa
- `IE`: Ireland
- sortBy (query): Sort order for Amazon product search results.

Available Values:
- `RELEVANCE`: Relevance
- `LOWEST_PRICE`: Lowest Price
- `HIGHEST_PRICE`: Highest Price
- `REVIEWS`: Reviews
- `NEWEST`: Newest
- `BEST_SELLERS`: Best Sellers
- productCondition (query): Product condition filter for Amazon search results.

Available Values:
- `ALL`: All product conditions
- `NEW`: New products
- `USED`: Used products
- `RENEWED`: Renewed products
- `COLLECTIBLE`: Collectible products
- isPrime (query): Whether to return only Prime-eligible products.
- dealsAndDiscounts (query): Deals and discounts filter for Amazon search results.

Available Values:
- `NONE`: Do not filter by deals or discounts
- `ALL_DISCOUNTS`: Return discounted products
- `TODAYS_DEALS`: Return today's deals
- page (query): Page number for pagination.

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/amazon/search-products/v1?token=YOUR_API_KEY&keyword=VALUE"
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/amazon/search-products/v1?token=YOUR_API_KEY&keyword=VALUE";

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/amazon/search-products/v1?token=YOUR_API_KEY&keyword=VALUE";

        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/amazon/search-products/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
<?php
$BASE_URL = "https://api.justoneapi.com"; // Mainland China: "http://47.117.133.51:30015"
$url = $BASE_URL . "/api/amazon/search-products/v1?token=YOUR_API_KEY&keyword=VALUE";

$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...