Перейти к основному содержанию
POST
/
v1
/
uploads
/
images
curl --request POST \
  --url https://api.apimart.ai/v1/uploads/images \
  --header 'Authorization: Bearer <token>' \
  --form 'file=@/path/to/your/image.jpg'
{
  "url": "https://upload.apimart.ai/f/image/9990000123456-a1b2c3d4-photo.jpg",
  "filename": "photo.jpg",
  "content_type": "image/jpeg",
  "bytes": 235680,
  "created_at": 1743436800
}

Documentation Index

Fetch the complete documentation index at: https://docs.apimart.ai/llms.txt

Use this file to discover all available pages before exploring further.

Playground документации не поддерживает загрузку файлов: используйте для тестирования примеры кода на cURL, Python или JavaScript ниже.
Важное изменение: Для повышения производительности и контроля затрат мы больше не поддерживаем передачу данных изображений в формате base64 напрямую в API генерации. Используйте этот API, чтобы загрузить изображение, получить URL и затем вызвать API генерации.

Зачем сначала загружать изображения?

  1. Оптимизация производительности — кодирование base64 увеличивает объём данных на 33%; предварительная загрузка значительно уменьшает размер тела запроса
  2. Повторное использование изображений — загрузите один раз и используйте URL многократно без повторных передач

Рабочий процесс

curl --request POST \
  --url https://api.apimart.ai/v1/uploads/images \
  --header 'Authorization: Bearer <token>' \
  --form 'file=@/path/to/your/image.jpg'
{
  "url": "https://upload.apimart.ai/f/image/9990000123456-a1b2c3d4-photo.jpg",
  "filename": "photo.jpg",
  "content_type": "image/jpeg",
  "bytes": 235680,
  "created_at": 1743436800
}

Авторизация

Authorization
string
обязательно
Все API требуют аутентификации с помощью Bearer TokenПолучите API-ключ:Перейдите на страницу управления API-ключами, чтобы получить API-ключДобавьте его в заголовки запроса:
Authorization: Bearer YOUR_API_KEY

Тело запроса

file
file
обязательно
Файл изображенияПоддерживаемые форматы: JPEG (.jpg, .jpeg), PNG (.png), WebP (.webp), GIF (.gif)Максимальный размер файла: 20 МБ

Ответ

url
string
Публичный URL доступа к изображению, можно использовать напрямую в API генерации (действителен 72 часа)
filename
string
Исходное имя файла
content_type
string
Определённый MIME-тип, например image/jpeg
bytes
integer
Размер файла в байтах
created_at
integer
Время загрузки в формате Unix-метки (в секундах)

Полный пример: рабочий процесс «изображение в изображение»

Python
import requests
import time

API_KEY = "your-Apimart-key"
BASE_URL = "https://api.apimart.ai"

# Step 1: Upload reference image
def upload_image(file_path):
    with open(file_path, 'rb') as f:
        response = requests.post(
            f"{BASE_URL}/v1/uploads/images",
            headers={"Authorization": f"Bearer {API_KEY}"},
            files={"file": f}
        )
    return response.json()['url']

# Step 2: Create generation task
def create_generation(image_url, prompt):
    response = requests.post(
        f"{BASE_URL}/v1/images/generations",
        headers={
            "Authorization": f"Bearer {API_KEY}",
            "Content-Type": "application/json"
        },
        json={
            "model": "gemini-3-pro-image-preview",
            "prompt": prompt,
            "image_urls": [{"url": image_url}],
            "size": "16:9"
        }
    )
    return response.json()['id']

# Step 3: Poll task status
def wait_for_result(task_id):
    while True:
        response = requests.get(
            f"{BASE_URL}/v1/images/generations/{task_id}",
            headers={"Authorization": f"Bearer {API_KEY}"}
        )
        result = response.json()

        if result['status'] == 'completed':
            return result['url']
        elif result['status'] == 'failed':
            raise Exception(f"Generation failed: {result.get('fail_reason')}")

        time.sleep(2)

# Execute workflow
image_url = upload_image("reference.jpg")
print(f"Image uploaded: {image_url}")

task_id = create_generation(image_url, "Transform this photo into Ghibli anime style")
print(f"Task created: {task_id}")

result_url = wait_for_result(task_id)
print(f"Generation complete: {result_url}")