Zum Hauptinhalt springen
TokenLab unterstützt Text-zu-Bild, Bild-zu-Bild und Bildbearbeitung über öffentliche Bildendpunkte. Bildmodelle teilen sich kein universelles Parameterset, daher sollten Produktionsclients zuerst den Endpunkt wählen, dann das Modell auswählen und anschließend nur die von diesem Modell unterstützten Felder senden.

Wann Jeder Endpunkt Verwendet Werden Soll

Benutzer-WorkflowEndpunktVerwenden, wennVermeiden, wenn
Text-zu-BildPOST /v1/images/generationsDer Benutzer beginnt nur mit einem PromptSie benötigen einen offiziellen GPT-Bildbearbeitungsfluss
Bild-zu-BildPOST /v1/images/generationsDie Modellspezifikationen beziehen sich auf Bilder über operation: "image-to-image" plus image_url, image_urls oder reference_image_urlsDas Modell erwartet multipart Bearbeitungseingaben
BildbearbeitungPOST /v1/images/editsSie bearbeiten ein vorhandenes Bild mit einem unterstützten Bearbeitungsmodell wie einem GPT-BildfamilienmodellSie verwenden die Nano Banana-Stil Bild-zu-Bild-Generierung
VariationPOST /v1/images/variationsSie pflegen eine legacy-variationskompatible IntegrationSie erstellen einen neuen Referenzbild-Workflow
StatusGET /v1/tasks/{id}Eine Erstellungsantwort gibt task_id, status: "pending" oder poll_url zurückDie Erstellungsantwort enthält bereits die endgültigen data[]
Senden Sie immer model. Bildendpunkte verlassen sich absichtlich nicht auf ein historisches implizites Standardmodell für Produktionsverkehr.

Wählen Sie Ein Modell

Beginnen Sie mit der Modellerkennung und überprüfen Sie den TokenLab-Vertrag des ausgewählten Modells:
curl "https://api.tokenlab.sh/v1/models?recommended_for=image" \
  -H "Authorization: Bearer sk-your-api-key"
Für Nicht-Chat-Modelle kann die Listenantwort tokenlab.public_contract_summary enthalten. Modell-Detailseiten können den umfassenderen tokenlab.public_contract offenlegen. Verwenden Sie diese Felder zur Bestätigung:
  • Die unterstützte Operation, wie text-to-image, image-to-image oder image-edit.
  • Den vom Modell erwarteten Anfrageendpunkt.
  • Welche Form für Referenzen verwendet werden soll, wie image_url, image_urls, reference_image_urls, multipart image oder JSON images[].
  • Ob das Modell size, aspect_ratio, resolution, quality, background, output_format oder response_format akzeptiert.

Regeln Für Die Anfrageform

  • Anfragen im Stil von gpt-image-2 verwenden OpenAI-ähnliche Felder wie size, quality und Bearbeitungsfelder. Lassen Sie optionale Felder weg, wenn Sie möchten, dass das Modell oder TokenLab automatische Standardwerte verwendet.
  • Die Bildfamilien Gemini und Nano Banana verwenden normalerweise aspect_ratio; senden Sie resolution nur, wenn der Modellvertrag es offenlegt.
  • Nano Banana Bild-zu-Bild gehört zu /v1/images/generations mit operation: "image-to-image" und Referenzbild-URLs.
  • /v1/images/generations akzeptiert keine obersten images[] oder file_id; das sind Formen für den Bearbeitungsfluss.
  • Remote-Bildreferenzen müssen öffentliche http oder https URLs sein. Senden Sie keine privaten Netzwerk-URLs, eingebetteten Anmeldeinformationen, URL-Fragmenten oder signierten URLs, die vor Beginn der Verarbeitung ablaufen könnten.

Text-Zu-Bild Beispiel

curl https://api.tokenlab.sh/v1/images/generations \
  -H "Authorization: Bearer sk-your-api-key" \
  -H "Content-Type: application/json" \
  -d '{
    "model": "gpt-image-2",
    "prompt": "Ein sauberes Produktfoto einer keramischen Kaffeetasse auf einem Walnusstisch",
    "size": "1024x1024",
    "response_format": "url"
  }'

Referenzbild Beispiel

curl https://api.tokenlab.sh/v1/images/generations \
  -H "Authorization: Bearer sk-your-api-key" \
  -H "Content-Type: application/json" \
  -d '{
    "model": "nano-banana",
    "operation": "image-to-image",
    "prompt": "Behalten Sie die Produktform bei, ändern Sie den Hintergrund in ein helles Studio-Setup",
    "image_urls": ["https://example.com/input/product.png"],
    "aspect_ratio": "1:1"
  }'

Ergebnisse Verarbeiten

Bildantworten können synchron oder asynchron sein:
  • Synchrone Antworten geben endgültige data[] mit url oder b64_json zurück.
  • Asynchrone Antworten geben id, task_id, status und normalerweise poll_url zurück.
  • Bevorzugen Sie poll_url, wenn es vorhanden ist. Wenn Sie eine feste Route benötigen, poll GET /v1/tasks/{id}.
  • Verwenden Sie synchrone Anfragen, wenn Sie speziell b64_json benötigen; asynchrone Bildresultate sind URL-orientiert.
curl "https://api.tokenlab.sh/v1/tasks/$TASK_ID" \
  -H "Authorization: Bearer sk-your-api-key"
Bewahren Sie die zurückgegebene Bild-URL, die Task-ID, das Modell und Ihre eigene Benutzer-/Job-ID auf. Pollen Sie nicht weiter, nachdem ein terminaler Status erreicht wurde.

Produktions-Checkliste

  • Validieren Sie Benutzereingaben, bevor Sie TokenLab aufrufen: Prompt-Länge, Bildanzahl, URL-Erreichbarkeit und Dateityp.
  • Setzen Sie HTTP-Timeouts hoch genug für synchrone hochauflösende Anfragen. Verwenden Sie den asynchronen Modus, wo verfügbar, für lange Arbeiten.
  • Speichern Sie request_id, task_id, poll_url, Modell, Endpunkt und bereinigte Anfrageform für den Support.
  • Überprüfen Sie bei einem Client-Timeout, ob eine Aufgabe erstellt wurde, bevor Sie die Erstellungsanfrage erneut versuchen.
  • Versöhnen Sie die Kosten mit den Nutzungsaufzeichnungen und billing_transaction_id, wenn vorhanden, nicht mit den Anbieter-Task-IDs.

Häufige Fehler

SymptomWahrscheinliche UrsacheLösung
400 mit param: "model"Fehlendes explizites ModellAbfragen von /v1/models?recommended_for=image und model senden
Nicht unterstütztes FeldFeld ist nicht im öffentlichen Vertrag dieses Modells enthaltenEntfernen Sie das Feld oder wählen Sie ein Modell/Endpunkt, das es dokumentiert
Kein b64_json bei asynchronem ErgebnisAsynchrone Bildaufgaben geben URL-orientierte Ergebnisse zurückVerwenden Sie den synchronen Modus für base64-Ausgaben
Referenzbild abgelehntFalscher Endpunkt oder private/abgelaufene URLEntsprechen Sie der dokumentierten Referenzform des Modells und verwenden Sie erreichbare URLs

API-Referenz

ThemaReferenz
Bild erstellenBild erstellen
Bild bearbeitenBild bearbeiten
Bildvariation erstellenBildvariation erstellen
Bildstatus abrufenBildstatus abrufen
Taskstatus abrufenTaskstatus abrufen