Aktuelle Kleinanzeigen-Daten per API abrufen: Suche, Inseratdetails, Verkäufer, Kategorien und Standorte.
Markdown direkt einfügen — oder die URL an deine KI schicken.
Schnellstart
Mit der API rufst du aktuelle Kleinanzeigen-Daten direkt in deiner eigenen Anwendung ab: Suche, Inseratdetails, Verkäuferprofile, Verkäufer-Inserate, Kategorien und Standorte. Du arbeitest mit normalen HTTP-Requests und JSON-Antworten.
Was du brauchst
Einen aktiven Kleinanzeigen-Agent Account.
Einen API-Key aus deinem Dashboard.
Ausreichend Credits für die Anfragen, die du ausführen willst.
Jede Antwort hat dieselbe Grundstruktur. Bei einer erfolgreichen Suche findest du die Treffer unter data.ads und Informationen zur Seite unter data.meta.
request_id ist die ID der Anfrage. Gib sie bei Support-Fragen mit an, damit wir den Request schneller finden können.
Defaults
page startet bei 0. size ist standardmäßig 31 und maximal 100. Alle Parameter und Antwortfelder verwenden snake_case.
Authentifizierung
Dein API-Key identifiziert deinen Account und ordnet die verbrauchten Credits deinem Guthaben zu. Sende ihn bei jeder API-Anfrage im Header klaz_key.
klaz_key: klaz_live_...
Für den MCP Server kannst du denselben Key auch als Bearer Token senden:
Authorization: Bearer klaz_live_...
API-Key verwalten
Du findest deinen API-Key im Dashboard. Der vollständige Key wird nur beim Erstellen oder Rotieren angezeigt. Danach siehst du aus Sicherheitsgründen nur noch eine maskierte Version.
Wenn ein Key versehentlich geteilt wurde, rotiere ihn im Dashboard. Der alte Key wird dadurch ungültig und du erhältst einen neuen.
Sicherer Einsatz
Speichere den Key in deiner Serverumgebung, zum Beispiel als Secret oder Environment Variable. Nutze ihn nicht direkt in öffentlichem Browser-Code und committe ihn nicht in dein Repository.
Sende den Key immer als Header. Verwende ihn nicht als Query-Parameter, weil URLs oft in Logs, Monitoring-Systemen oder Browser-Historien landen.
Typische Auth-Fehler
401 bedeutet, dass der Header fehlt oder der Key ungültig ist. Prüfe in diesem Fall den Headernamen klaz_key, den vollständigen Key-Wert und ob der Key im Dashboard rotiert wurde.
429 bedeutet, dass dein aktuelles Rate Limit erreicht wurde. Reduziere die Anfragefrequenz oder wähle einen Plan mit höherem Limit.
API Referenz
Diese Endpunkte sind für deine Anwendung gedacht. Alle Requests sind GET-Requests, benötigen den Header klaz_key und liefern JSON zurück.
Inserate suchen
GET /api/v2/kleinanzeigen/search
Nutze diesen Endpoint für Suchseiten, Preisvergleiche, Monitoring oder Matching in deiner Anwendung.
Parameter:
q string: Suchbegriff.
page integer, Default 0: Ergebnis-Seite, startet bei 0.
size integer, Default 31: Ergebnisse pro Seite, maximal 100.
category_id string: Kleinanzeigen-Kategorie.
location_id string: Kleinanzeigen-Standort. Nicht zusammen mit latitude und longitude verwenden.
distance string: Umkreis in Kilometern.
min_price integer: Mindestpreis.
max_price integer: Höchstpreis.
picture_required boolean: Nur Inserate mit Bildern.
buy_now_only boolean: Nur Direktkauf-Inserate.
shippable boolean: Nur Inserate mit Versand.
ad_type enum: OFFER oder WANTED. OFFER ist die normale
Angebotssuche und wird nicht extra an Kleinanzeigen gesendet. Nur WANTED
wird als Gesuch-Filter weitergereicht.
poster_type enum: PRIVATE oder COMMERCIAL.
latitude number: Breitengrad. Nur zusammen mit longitude.
longitude number: Längengrad. Nur zusammen mit latitude.
attr[...] string: Kategorieattribute, zum Beispiel attr[condition]=new.
sort_type ist aktuell nicht verfügbar. Die API antwortet mit 400, wenn der Parameter gesendet wird.
Die Antwort enthält data.meta und data.ads. data.meta enthält page, size, total, exact_total, has_next_page, next_page und source; Paging bleibt damit auf unserer API-Oberfläche und enthält keine Upstream-URLs. Jedes Inserat kommt in einem konsistenten Format zurück. shipping_available ist true, false oder null, wenn Kleinanzeigen in der Antwort kein zuverlässiges Versandsignal liefert; shippable=true filtert trotzdem serverseitig bei Kleinanzeigen.
Kleinanzeigen liefert in Suchantworten oft keine user-id. seller.seller_id kann deshalb bei /searchnull sein; nutze GET /api/v2/kleinanzeigen/ads/:ad_id, wenn du die Verkäufer-ID zuverlässig brauchst.
Genau diese Filter kannst du auch für Webhooks verwenden. Wir fragen die
Live-Suche im gebuchten Intervall automatisch für dich ab und schicken dir
jedes passende Inserat genau einmal.
Inseratdetails abrufen
GET /api/v2/kleinanzeigen/ads/:ad_id
Parameter:
ad_id numeric string, erforderlich: Kleinanzeigen-Inserat-ID im Pfad.
include_views boolean, Default false: Lädt zusätzlich die Aufrufzahl und berechnet einen Extra-Credit.
GET /api/v2/kleinanzeigen/sellers/:seller_id/profile
Parameter:
seller_id string, erforderlich: Verkäufer-ID aus ad.seller.seller_id.
Die Antwort nutzt das echte öffentliche Kleinanzeigen-Profil. Sie ist nicht aus den Inseraten zusammengesetzt. Je nach Verkäufer kann Kleinanzeigen einzelne Felder weglassen; deshalb sind viele Felder nullable.
seller_id string, erforderlich: Verkäufer-ID aus ad.seller.seller_id.
page integer, Default 0: Ergebnis-Seite.
size integer, Default 31: Ergebnisse pro Seite, maximal 100.
Die Antwort entspricht der Suchantwort mit data.meta und data.ads.
Kategorien
GET /api/v2/kleinanzeigen/categories
GET /api/v2/kleinanzeigen/categories/:category_id/metadata
GET /api/v2/kleinanzeigen/categories/:category_id/search-metadata
Nutze Kategorien, um Suchanfragen genauer einzugrenzen und passende Filter für deine Oberfläche zu bauen.
/categories liefert den Kategoriebaum. metadata liefert verfügbare Felder für eine Kategorie. search-metadata liefert Suchfilter und Attribute, die du für attr[...] verwenden kannst.
Nutze Standorte für Autocomplete, regionale Suchen und Umkreissuchen. Die Standortliste wird flach zurückgegeben, damit du sie direkt in Suchfeldern oder Matchern verwenden kannst.
MCP Server
Der MCP Server stellt die Live-Kleinanzeigen-Daten als Tools für LLM-Clients bereit. Ein Client wie ein Agent, eine IDE-Erweiterung oder ein internes Chat-Tool kann damit nicht nur über Kleinanzeigen-Daten reden, sondern gezielt Live-Suchen ausführen, Inseratdetails nachladen und Ergebnisse weiterverarbeiten.
Kurz gesagt: MCP ist kein Ersatz für die REST API. MCP ist eine zusätzliche Schnittstelle für KI-Clients, die selbst entscheiden sollen, wann sie welches Werkzeug aufrufen.
Wann du MCP verwenden solltest
Nutze MCP, wenn ein LLM interaktiv mit Live-Daten arbeiten soll:
Recherche-Assistenten, die erst suchen und dann einzelne Treffer prüfen.
Agenten, die Verkäufer, Kategorien oder Standorte abhängig vom Zwischenergebnis nachladen.
Interne Tools, in denen ein Mensch Fragen stellt und der Client passende Kleinanzeigen-Tools aufruft.
Marktanalysen, bei denen ein Modell mehrere Suchen ausführt und daraus eine Tabelle oder Shortlist erstellt.
Nutze stattdessen die REST API, wenn dein eigenes Backend deterministisch Requests ausführt. Nutze Webhooks, wenn du dauerhaft neue Inserate zu gespeicherten Filtern überwachen willst.
Endpoint
https://api.kleinanzeigen-agent.de/mcp
Der Server spricht MCP über Streamable HTTP. Normale Tool-Aufrufe laufen über POST /mcp. Der Body ist MCP/JSON-RPC und wird normalerweise von deinem MCP-Client erzeugt; du musst diese JSON-RPC-Nachrichten nicht selbst schreiben, wenn dein Client MCP-Server über HTTP unterstützt.
Authentifizierung
Der MCP Server nutzt denselben API-Key wie die normale Kleinanzeigen Agent API. Empfohlen ist der Bearer-Header:
Authorization: Bearer klaz_live_...
Aus Kompatibilitätsgründen akzeptiert der MCP Endpoint auch den bestehenden API-Header:
klaz_key: klaz_live_...
Speichere den Key als Secret in deinem MCP Client. Gib ihn nicht in einen Prompt ein, hänge ihn nicht an die URL und committe ihn nicht in eine Config-Datei. Wenn ein Key öffentlich geworden ist, rotiere ihn im Dashboard.
Tools
Alle Tools liefern JSON im gleichen success, message, data, error_code-Stil wie die REST API zurück. Das Ergebnis wird als MCP Tool Content zurückgegeben; dein Client kann es anzeigen, zusammenfassen oder für den nächsten Tool-Aufruf verwenden.
Wenn ein Agent sehr viele Treffer sammeln, stark filtern oder eigene kompakte Zwischenergebnisse bauen soll, kann er statt weiterer MCP Tool Calls auch direkt die REST API nutzen. Die komplette API-Doku gibt es dafür als Markdown unter https://kleinanzeigen-agent.de/api/docs-raw, damit KI-Clients sie direkt lesen können. Derselbe klaz_live_... API-Key funktioniert dort ebenfalls: als Authorization: Bearer ... Header oder als klaz_key Header. Der Key gehört trotzdem in Secrets oder Umgebungsvariablen, nicht in Prompts, Logs oder Code.
Tool
Typische Eingaben
Zweck
Credits
search_kleinanzeigen
q, category_id, location_id, distance, Preisfilter, Versandfilter, Attribute
Live-Inserate suchen
1
get_kleinanzeigen_ad
ad_id, optional include_views
Inseratdetails laden
1
get_kleinanzeigen_ad_status
ad_id, optional include_views
Prüfen, ob ein Inserat aktiv oder gelöscht ist
1
get_kleinanzeigen_seller_profile
seller_id
Öffentliches Verkäuferprofil mit Name, Badges und Zählern laden
1
get_kleinanzeigen_seller_ads
seller_id, page, size
Weitere Inserate eines Verkäufers laden
2
list_kleinanzeigen_categories
keine
Kategoriebaum laden
1
get_kleinanzeigen_category_metadata
category_id
Felder einer Kategorie ansehen
1
get_kleinanzeigen_category_search_metadata
category_id
Suchfilter und Attribute einer Kategorie laden
1
search_kleinanzeigen_locations
q oder Koordinaten, optional limit
Standorte suchen
1
get_kleinanzeigen_location
location_id
Standortdetails laden
1
Bei get_kleinanzeigen_ad und get_kleinanzeigen_ad_status kostet include_views=true einen zusätzlichen Credit.
page ist 0-basiert: Die erste Ergebnisseite ist page: 0. Wenn ein MCP Client versehentlich eine Seite außerhalb des vorhandenen Ergebnisbereichs anfragt, lädt das Tool automatisch die letzte verfügbare Seite nach.
sort_type wird von der Live-Suche aktuell nicht unterstützt. Wenn du sortierte Ergebnisse brauchst, lass deinen MCP Client die zurückgegebenen Inserate nach Preis, Datum oder anderem Feld sortieren.
Ungültige Tool-Argumente kosten keine Credits. Wenn ein Live-Call wegen eines Upstream-Problems fehlschlägt, wird der Credit wie bei der REST API automatisch zurückerstattet. Rate Limits hängen weiter an deinem Plan.
Beispiel-Config
Viele MCP Clients erlauben Remote-Server mit eigenen Headern. Konfiguriere den Server sinngemäß so:
Danach sollte dein Client die Tools selbst entdecken. Je nach Client heißt die Funktion zum Hinzufügen eines Servers anders, aber die drei wichtigen Teile bleiben gleich: URL, Transport über HTTP und der Authorization Header.
Codex CLI
Wenn du Codex lokal nutzt, kannst du den MCP Server direkt über die CLI hinzufügen.
Setze deinen API-Key zuerst als Umgebungsvariable:
In Claude Code zeigt /mcp den Serverstatus und die verfügbaren Tools.
Der Befehl schreibt die Verbindung in deine lokale Claude-Code-Konfiguration. Nutze dafür keinen geteilten Projekt-Scope mit einem echten API-Key.
Beispiel-Fragen an den Client
Nachdem der Server verbunden ist, kannst du dem Client normale Aufgaben geben. Gute Prompts nennen Ziel, Filter und gewünschtes Ausgabeformat:
Suche private iPhone 15 Angebote im Umkreis von 25 km um Berlin.
Lade Details für die 5 günstigsten Treffer nach und gib mir eine Tabelle mit Preis, Standort, Versand, Verkäufer und URL.
Finde Sofas bis 300 EUR in München, nur mit Bildern.
Markiere auffällige Angebote und erkläre kurz, warum sie interessant sein könnten.
Der Client entscheidet dann selbst, ob er nur search_kleinanzeigen braucht oder zusätzlich Details, Verkäuferprofile, Verkäufer-Inserate, Kategorien oder Standorte nachladen sollte.
Sicherheit und Grenzen
MCP gibt dem LLM Zugriff auf die Kleinanzeigen-Tools, nicht auf dein ganzes Konto. Dein API-Key bleibt in deinem MCP-Client und wird bei Tool-Aufrufen als Header gesendet.
Der MCP Server speichert keine Inserate und ersetzt keinen Webhook. Er ist für interaktive Recherche und agentische Workflows gedacht. Für produktive Entscheidungen solltest du wichtige Ergebnisse mit ad_id, Preis, URL und Zeitpunkt ausgeben lassen und bei Bedarf selbst prüfen.
Was dein MCP Client können muss
Dein MCP Client muss Remote-Server über HTTP verbinden können und eigene Header unterstützen. Wichtig ist dieser Header:
Authorization: Bearer klaz_live_...
Wenn dein Client keine eigenen Header für MCP Server erlaubt, kannst du diesen MCP Server dort aktuell nicht direkt verbinden. Nutze in dem Fall die REST API oder einen MCP Client, der Header unterstützt.
Häufige Fehler
Problem
Ursache
Lösung
401 API_KEY_MISSING
Kein Header oder falscher Headername
Authorization: Bearer klaz_live_... setzen
401 API_KEY_INVALID
Key falsch, rotiert oder deaktiviert
Key im Dashboard prüfen oder rotieren
402 INSUFFICIENT_CREDITS
Zu wenig Guthaben
Credits kaufen oder Plan upgraden
403 MCP_ORIGIN_NOT_ALLOWED
Client sendet eine nicht erlaubte Origin
Wenn möglich keinen Browser-Origin senden oder Support kontaktieren
Client findet keine Tools
MCP Server nicht korrekt verbunden
URL, HTTP-Transport und Authorization Header im Client prüfen
Webhooks
Lass dir neue Inserate automatisch an deinen Server schicken, sobald sie auf
Kleinanzeigen erscheinen — passend zu deinen Filtern, im gewählten Intervall.
Jedes Inserat erreicht dich genau einmal pro Webhook. Auch wenn ein Inserat
noch tagelang in der Suche steht, schicken wir es nicht erneut.
Tarife
Webhooks haben ihr eigenes Abo. Dein API-Guthaben und dein Rate-Limit bleiben
davon unberührt.
Tarif
Intervall
Preis netto
Webhook Pulse
60 Sekunden
39 EUR / Monat
Webhook Flow
30 Sekunden
79 EUR / Monat
Webhook Stream
10 Sekunden
229 EUR / Monat
Webhook Realtime
3 Sekunden
749 EUR / Monat
Ein Abo entspricht einem aktiven Webhook mit einem Suchfilter und einer
Ziel-URL.
Filter
Webhooks nutzen genau die Filter, die du auch von der Live-Suche kennst:
GET /api/v2/kleinanzeigen/search
Verfügbar sind unter anderem q, category_id, location_id, distance,
min_price, max_price, picture_required, buy_now_only, shippable,
ad_type, poster_type, latitude, longitude sowie kategoriespezifische
attr[...]-Werte. ad_type=OFFER ist die normale Angebotssuche und wird nicht
extra an Kleinanzeigen gesendet. Nur ad_type=WANTED wird als Gesuch-Filter
weitergereicht.
Lieferung
Sobald wir ein neues Inserat finden, schicken wir dir einen POST an deine
Ziel-URL.
Im Dashboard kannst du jederzeit eine Testlieferung auslösen. Sie ist signiert
wie eine echte Lieferung und enthält keine Inserate, damit du deinen Endpunkt
und die Signaturprüfung in Ruhe einspielen kannst.
Fehler, Credits und Limits
Die API soll für deine Anwendung vorhersehbar sein: ungültige Requests verbrauchen keine Credits, erfolgreiche Requests werden nach Aktion berechnet, und fehlgeschlagene Live-Anfragen werden automatisch erstattet.
Fehlerantwort
Jede Fehlerantwort enthält ein maschinenlesbares error_code und eine message für Menschen. Bei Validierungsfehlern listet errors die betroffenen Felder. Bei manchen Fehlern liefert data zusätzliche Hinweise (z. B. fehlende Credits oder weiterführende Links).
{
"success": false,
"error_code": "INVALID_PARAMETERS",
"message": "Invalid request parameters",
"errors": {
"min_price": ["min_price must be less than or equal to max_price"]
},
"request_id": "req_..."
}
Statuscodes
400: Ungültige Parameter, ungültige Pfad-ID oder ein vom Upstream zurückgewiesener Request.
401: klaz_key fehlt oder ist ungültig.
402: Nicht genug Credits.
404: Ressource wurde upstream nicht gefunden.
429: Planlimit erreicht oder Kleinanzeigen selbst hat das Limit ausgelöst.
500: Unerwarteter Serverfehler.
502: Kleinanzeigen hat abgelehnt oder ist temporär nicht verfügbar.
504: Timeout bei der Live-Anfrage.
Error Codes
Diskriminiere im Client auf error_code — die Codes sind stabil, während sich die message-Texte ändern können.
error_code
Status
Bedeutung
INVALID_PARAMETERS
400
Validierung fehlgeschlagen. errors enthält die Feldfehler.
INVALID_AUTH_CONTEXT
400
Auth-Header technisch fehlerhaft. Prüfe klaz_key.
API_KEY_MISSING
401
Kein klaz_key Header gesetzt. data.signup_url führt zur Anmeldung.
API_KEY_INVALID
401
Schlüssel unbekannt oder Account inaktiv. Neuen Schlüssel im Dashboard erzeugen.
INSUFFICIENT_CREDITS
402
Aktion zu teuer. data.required_credits und data.available_credits sind gesetzt; data.buy_credits_url und data.upgrade_url führen zur Abrechnung.
UPSTREAM_BAD_REQUEST
400
Kleinanzeigen hat den Request zurückgewiesen.
UPSTREAM_NOT_FOUND
404
Inserat, Verkäufer, Kategorie oder Standort existiert dort nicht (mehr).
UPSTREAM_RATE_LIMITED
429
Kleinanzeigen drosselt. Kurz warten und erneut versuchen — kein Plan-Upgrade nötig.
PLAN_RATE_LIMIT_EXCEEDED
429
Dein per-Minute-Limit ist erreicht. data.upgrade_url zeigt auf die Abrechnung.
INGRESS_RATE_LIMIT_EXCEEDED
429
Globales IP-Limit erreicht (sehr hoch angesetzt, normalerweise nur bei sehr aggressivem Traffic).
UPSTREAM_UNAVAILABLE
502
Kleinanzeigen ist gerade nicht erreichbar. Wird automatisch retryed.
UPSTREAM_TIMEOUT
504
Antwort kam nicht rechtzeitig. Erneut versuchen.
INTERNAL_ERROR
500
Unerwarteter Fehler bei uns. request_id mitsenden, wenn du Support kontaktierst.
Bei INSUFFICIENT_CREDITS enthält data die Credit-Zähler (required_credits, available_credits) plus buy_credits_url, upgrade_url, plans_url. Bei API_KEY_MISSING, API_KEY_INVALID und PLAN_RATE_LIMIT_EXCEEDED enthält data weiterführende URLs (signup_url, api_keys_url, docs_url, upgrade_url, plans_url), damit du Endnutzer:innen direkt zum richtigen Schritt schicken kannst.
Credit-Kosten
Kosten:
Live-Suche: 1 Credit.
Verkäuferprofil: 1 Credit.
Verkäufer-Inserate: 2 Credits.
Inseratdetails: 1 Credit.
Inseratstatus: 1 Credit.
Views zusätzlich laden: 1 Credit.
Kategorien: 1 Credit.
Kategorie-Metadaten: 1 Credit.
Standorte: 1 Credit.
include_views=true addiert den Views-Credit zur jeweiligen Anfrage. Ein Detailabruf mit Views kostet also 2 Credits, ein Statusabruf mit Views kostet 2 Credits.
Live-Daten
Die API liefert aktuelle Daten aus der Live-Abfrage. Sie ist nicht als historisches Archiv gedacht und liefert keine gespeicherten Suchergebnisse aus früheren Läufen.
Verbindung und Stabilität
Du musst keine Proxy-Daten, Cookies oder Kleinanzeigen-spezifische Verbindungseinstellungen konfigurieren. Wir kümmern uns um Routing, Timeouts, Normalisierung und retryfähige Verbindungsfehler.
Aktuelle Einschränkungen
Die erste v2-Version konzentriert sich auf Live-Abfragen. Gespeicherte Suchhistorie, Harvesting und Raw-Antworten sind nicht Teil dieser API. sort_type ist aktuell deaktiviert: Die REST API lehnt den Parameter mit INVALID_PARAMETERS ab, das MCP-Tool bewirbt ihn nicht und entfernt ihn defensiv, falls ein Client ihn trotzdem mitsendet.