API de generación de imágenes Minimax

Modelo chino avanzado con excelente comprensión artística.

✓ Generación asíncrona

✓ Múltiples estilos

✓ Alta calidad

✓ Soporte para lotes

Autenticación

Para acceder a Minimax Image a través de la API de Doitong, usa tu clave de API de Doitong. Inclúyela en la mutación de GraphQL o en los encabezados de la API REST.

Importante: Mantén tu clave de API de Doitong en un lugar seguro y nunca la expongas en el código del lado del cliente. Realiza siempre las llamadas a la API desde tu servidor backend.
// GraphQL Header
{
  "Authorization": "Bearer YOUR_API_KEY"
}

// REST Header
"X-API-Key": "YOUR_API_KEY"

Inicio rápido

Comienza a usar Minimax Image API en solo unos minutos. Sigue estos sencillos pasos para generar tu primer text to image.

Paso 1: Obtén tu clave de API

Regístrate para obtener una cuenta de Doitong y dirígete a tu panel de control para generar una clave de API.

Paso 2: Realiza tu primera solicitud

Usa uno de los ejemplos de código a continuación para realizar tu primera llamada a la API.

curl -X POST https://api.doitong.com/graphql \
  -H "Content-Type: application/json" \
  -H "Authorization: Bearer YOUR_API_KEY" \
  -d '{
    "query": "mutation Generate($input: GenerateInput!) { generate(input: $input) { id status type provider url metadata creditCost } }",
    "variables": {
      "input": {
        "type": "IMAGE",
        "provider": "minimax-image",
        "input": {
          "text": "A futuristic city with flying cars and neon lights"
        },
        "options": {
          "width": 1024,
          "height": 1024
        }
      }
    }
  }'
const response = await fetch('https://api.doitong.com/graphql', {
  method: 'POST',
  headers: {
    'Content-Type': 'application/json',
    'Authorization': 'Bearer YOUR_API_KEY'
  },
  body: JSON.stringify({
    query: `
      mutation GenerateImage($input: ImageGenerationInput!) {
        generateImage(input: $input) {
          id
          url
          width
          height
        }
      }
    `,
    variables: {
      input: {
        service: 'minimax-image',
        prompt: 'A futuristic city with flying cars and neon lights',
        width: 1024,
        height: 1024
      }
    }
  })
});

const data = await response.json();
console.log('Image:', data.data.generateImage);
import requests
import json

url = "https://api.doitong.com/graphql"
headers = {
    "Content-Type": "application/json",
    "Authorization": "Bearer YOUR_API_KEY"
}

query = """
mutation Generate($input: GenerateInput!) {
  generate(input: $input) {
    id
    status
    type
    provider
    url
    metadata
    creditCost
  }
}
"""

variables = {
    "input": {
        "type": "IMAGE",
        "provider": "minimax-image",
        "input": {
            "text": "A futuristic city with flying cars and neon lights"
        },
        "options": {
            "width": 1024,
            "height": 1024
        }
    }
}

response = requests.post(url, json={
    "query": query,
    "variables": variables
}, headers=headers)

data = response.json()
print("Result:", data["data"]["generate"])
mutation Generate($input: GenerateInput!) {
  generate(input: $input) {
    id
    status
    type
    provider
    url
    metadata
    creditCost
    createdAt
  }
}

# Variables
{
  "input": {
    "type": "IMAGE",
    "provider": "minimax-image",
    "input": {
      "text": "A futuristic city with flying cars and neon lights"
    },
    "options": {
      "width": 1024,
      "height": 1024,
      "version": "minimax-v1",
      "quality": "high"
    }
  }
}

Precios

Minimax Image API utiliza un modelo de precios basado en créditos. Los créditos se consumen según la complejidad y la duración del contenido generado.

Función Créditos Descripción
Resolución estándar 10-20 Créditos De 512x512 a 1024x1024 píxeles
Alta resolución 30-50 Créditos 2048x2048 píxeles o más

Endpoints de la API

Minimax Image API está disponible a través de nuestro endpoint unificado de GraphQL.

Endpoint de GraphQL

POST https://api.doitong.com/graphql

Endpoint de REST

POST https://api.doitong.com/v1/text_to_image

Parámetros

Parámetros disponibles para las solicitudes de Minimax Image API:

Parámetro Tipo Obligatorio Descripción
service String Yes Identificador del servicio: "minimax-image"
prompt String Yes Descripción en texto de lo que se desea generar
width Entero No Ancho de la imagen en píxeles (por defecto: 1024)
height Entero No Alto de la imagen en píxeles (por defecto: 1024)
version String No Model version: "minimax-v1"
webhookUrl String No URL para recibir notificaciones de finalización

Formato de respuesta

Todas las respuestas de la API siguen un formato consistente:

Respuesta exitosa

{
  "data": {
    "generateimage": {
      "id": "abc123xyz",
      "status": "processing",
      "url": null,
      "webhookUrl": "https://your-webhook.com/callback",
      "createdAt": "2024-01-01T00:00:00Z"
    }
  }
}

Respuesta completada

{
  "data": {
    "generateimage": {
      "id": "abc123xyz",
      "status": "completed",
      "url": "https://cdn.doitong.com/outputs/abc123xyz.jpg",
      "duration": null,
      "createdAt": "2024-01-01T00:00:00Z"
    }
  }
}

Gestión de errores

La API utiliza códigos de estado HTTP estándar y devuelve mensajes de error detallados.

Códigos de error comunes

Código de estado Tipo de error Descripción
400 Bad Request Invalid parameters or malformed request
401 Unauthorized Missing or invalid API key
402 Payment Required Insufficient credits
429 Too Many Requests Rate limit exceeded
500 Internal Server Error Server error, please retry

Formato de respuesta de error

{
  "errors": [
    {
      "message": "Insufficient credits for this operation",
      "extensions": {
        "code": "INSUFFICIENT_CREDITS",
        "creditsRequired": 100,
        "creditsAvailable": 50
      }
    }
  ]
}

Webhooks

Recibe notificaciones en tiempo real cuando se complete la generación de tu text to image.

Configuración de webhooks

Include a <code>webhookUrl</code> parameter in your request to receive a POST notification when processing is complete.

Payload del webhook

{
  "id": "abc123xyz",
  "status": "completed",
  "url": "https://cdn.doitong.com/outputs/abc123xyz.jpg",
  "service": "minimax-image",
  "createdAt": "2024-01-01T00:00:00Z",
  "completedAt": "2024-01-01T00:01:00Z",
  "metadata": {
    "duration": null,
    "width": 1920,
    "height": 1080
  }
}

Seguridad del webhook

Todas las solicitudes de webhook incluyen un encabezado de firma para su verificación:

X-Doitong-Signature: sha256=abc123...

Límites de tasa

Para garantizar un uso justo y la estabilidad del sistema, se aplican los siguientes límites de tasa:

Plan Solicitudes/minuto Tareas simultáneas Límite diario
Gratis 10 1 100
Starter 30 3 1,000
Pro 60 10 10,000
Enterprise Personalizado Personalizado Ilimitado
Encabezados de límite de tasa: Consulta los encabezados de respuesta para conocer el estado actual de los límites:
  • X-RateLimit-Limit: Maximum requests per window
  • X-RateLimit-Remaining: Requests remaining
  • X-RateLimit-Reset: Window reset timestamp

Mejores prácticas

1. Optimiza tus prompts

Escribe prompts claros y descriptivos para obtener los mejores resultados:

  • Be specific about visual elements, style, and mood
  • Include details about lighting, camera angles, and composition
  • Avoid contradictory or impossible requests

2. Gestiona el procesamiento asíncrono

La generación es asíncrona. Implementa un sistema de sondeo (polling) o webhooks adecuado:

// Polling example
async function pollStatus(jobId) {
  let status = 'processing';
  while (status === 'processing') {
    await sleep(2000); // Wait 2 seconds
    const result = await checkJobStatus(jobId);
    status = result.status;
  }
  return result;
}

3. Recuperación de errores

Implementa una lógica de reintento con retroceso exponencial (exponential backoff):

async function retryWithBackoff(fn, maxRetries = 3) {
  for (let i = 0; i < maxRetries; i++) {
    try {
      return await fn();
    } catch (error) {
      if (i === maxRetries - 1) throw error;
      await sleep(Math.pow(2, i) * 1000);
    }
  }
}

4. Supervisa el uso de créditos

Realiza un seguimiento de tu consumo de créditos para evitar interrupciones:

  • Check credit balance before large batch operations
  • Set up alerts for low credit thresholds
  • Implement credit-aware request queuing

¿Todo listo para empezar?

Únete a miles de desarrolladores que usan Minimax Image API para crear contenido increíble

Obtener clave de API Ver precios