Die Merchant API bietet eine robustere und intuitivere Möglichkeit, Ihre Produktdaten zu verwalten. Die wichtigste Änderung ist die Aufteilung der Produktdaten in zwei separate Ressourcen: ProductInput
zum Einreichen Ihrer Daten und Product
zum Aufrufen der endgültigen, verarbeiteten Version mit Produktstatus und Problemen. Diese neue Struktur sorgt für mehr Vorhersehbarkeit und Transparenz.
In diesem Leitfaden werden die wichtigsten Unterschiede beschrieben, damit Sie Ihre Integration von der Content API for Shopping migrieren können. Eine detaillierte Anleitung zur Verwendung der neuen Funktionen finden Sie unter Produkte verwalten.
Wichtige Unterschiede
Im Folgenden finden Sie die wichtigsten Änderungen bei der Verwaltung von Produkten in der Merchant API im Vergleich zur Content API for Shopping:
Spezielle Ressourcen für Eingabe- und verarbeitete Daten: Mit der Merchant API wird die Produktverwaltung in zwei Ressourcen aufgeteilt. Mit der Ressource
ProductInput
können Sie Ihre Produktdaten einfügen, aktualisieren und löschen. Mit der schreibgeschütztenProduct
-Ressource können Sie das endgültige Produkt ansehen, nachdem Google Ihre Eingaben verarbeitet, Regeln angewendet und Daten aus zusätzlichen Quellen kombiniert hat.Status des integrierten Produkts: Der
productstatuses
-Dienst wird entfernt. Probleme bei der Produktvalidierung und Zielstatus sind jetzt direkt in derProduct
-Ressource im FeldproductStatus
enthalten, was den Datenabruf vereinfacht.Vorhersehbare Produktupdates: Mit der neuen Methode
productInputs.patch
wird eine bestimmte Produkteingabe direkt geändert. Das ist eine deutliche Verbesserung gegenüber der Content API for Shopping, bei der Aktualisierungen unerwartet durch andere Feeduploads überschrieben werden konnten. In der Merchant API bleibt eine Aktualisierung erhalten, bis die entsprechende Produkteingabe noch einmal aktualisiert oder gelöscht wird. Produktaktualisierungen werden auf die RessourceProductInput
angewendet und nicht auf die verarbeitete RessourceProduct
.Datenquelle für eine übersichtlichere Datenverwaltung auswählen: Für alle
productInputs
-Schreibvorgänge ist jetzt eindataSource
-Abfrageparameter erforderlich. So wird explizit angegeben, welche Datenquelle Sie ändern. Das ist besonders nützlich, wenn Sie Daten aus mehreren Quellen beziehen.Neue Ressourcen-IDs: Produkte werden jetzt durch eine RESTful-Ressource
name
anstelle des Feldsid
identifiziert. Das Format dafür istaccounts/{account}/products/{product}
.Keine benutzerdefinierten Batches: Die Methode
custombatch
ist nicht mehr verfügbar. Sie können asynchrone Anfragen oder HTTP-Batching verwenden, um mehrere Anfragen in einem einzelnen HTTP-Aufruf zu senden.Datenquellen für jedes Feedlabel und jede Sprache: Mit der Merchant API können Sie Datenquellen erstellen, ohne Feedlabel und Sprache anzugeben. So lassen sich Produkte mit beliebigen Feedlabels und Sprachen einfügen.
Anfragen
In diesem Abschnitt werden die Anfrageformate für die Content API for Shopping und die Merchant API verglichen.
Beschreibung der Anfrage | Content API for Shopping | Merchant API |
---|---|---|
Produkt kaufen | GET https://shoppingcontent.googleapis.com/content/v2.1/{merchantId}/products/{productId} |
GET https://merchantapi.googleapis.com/products/v1/accounts/{account}/products/{product} |
Produkte auflisten | GET https://shoppingcontent.googleapis.com/content/v2.1/{merchantId}/products |
GET https://merchantapi.googleapis.com/products/v1/accounts/{account}/products |
Produkt einfügen | POST https://shoppingcontent.googleapis.com/content/v2.1/{merchantId}/products |
POST https://merchantapi.googleapis.com/products/v1/accounts/{account}/productInputs:insert |
Produkt aktualisieren | PATCH https://shoppingcontent.googleapis.com/content/v2.1/{merchantId}/products/{productId} |
PATCH https://merchantapi.googleapis.com/products/v1/accounts/{account}/productInputs/{productinput} |
Produkt löschen | DELETE https://shoppingcontent.googleapis.com/content/v2.1/{merchantId}/products/{productId} |
DELETE https://merchantapi.googleapis.com/products/v1/accounts/{account}/productInputs/{productinput} |
Produktstatus abrufen | GET https://shoppingcontent.googleapis.com/content/v2.1/{merchantId}/productstatuses/{productId} |
GET https://merchantapi.googleapis.com/products/v1/accounts/{account}/products/{product} |
Produktstatus auflisten | GET https://shoppingcontent.googleapis.com/content/v2.1/{merchantId}/productstatuses |
GET https://merchantapi.googleapis.com/products/v1/accounts/{account}/products |
Mehrere Anfragen in einem Batch zusammenfassen | POST https://shoppingcontent.googleapis.com/content/v2.1/products/custombatch |
Asynchrone Anfragen, HTTP-Batching |
IDs
Das Format für Produkt-IDs wurde in der Merchant API in einen standardmäßigen REST-Ressourcennamen geändert.
Beschreibung der Kennung | Content API for Shopping | Merchant API |
---|---|---|
Produkt-ID | Ein String, der aus durch einen Doppelpunkt (: ) getrennten Segmenten besteht.Format: channel:contentLanguage:targetCountry:offerId oder channel:contentLanguage:feedLabel:offerId .Beispiel: online:en:US:sku123 |
Ein REST-Ressourcenstring name .Format: accounts/{account}/products/{product} , wobei {product} contentLanguage~feedLabel~offerId ist.Beispiel: accounts/12345/products/en~US~sku123 |
Methoden
In dieser Tabelle finden Sie die Content API for Shopping-Methoden und ihre Entsprechungen in der Merchant API.
Content API for Shopping-Methode | Merchant API-Methode | Verfügbarkeit und Hinweise |
---|---|---|
products.get |
products.get |
Ruft das endgültige, verarbeitete Produkt ab. |
products.list |
products.list |
Listet die endgültigen, verarbeiteten Produkte auf. |
products.insert |
productInputs.insert |
Fügt eine Produkteingabe ein. Erfordert ein dataSource . |
products.update |
productInputs.update |
Das Verhalten ist deutlich anders. Damit wird eine bestimmte Produkteingabe aktualisiert. Die Änderung ist dauerhaft. |
products.delete |
productInputs.delete |
Löscht eine bestimmte Produkteingabe. Erfordert ein dataSource . |
products.custombatch |
Nicht verfügbar | Verwenden Sie asynchrone Anfragen oder HTTP-Batching. |
productstatuses.get |
products.get |
Der Dienst productstatuses wird entfernt. Statusinformationen sind jetzt Teil der Product -Ressource. |
productstatuses.list |
products.list |
Der Dienst productstatuses wird entfernt. Statusinformationen sind jetzt Teil der Product -Ressource. |
productstatuses.custombatch |
Nicht verfügbar | [asynchronous |
requests](/merchant/api/samples/insert-product-input-async) oder HTTP-Batching. |
Detaillierte Feldänderungen
In dieser Tabelle werden wichtige Felder hervorgehoben, die in der Merchant API geändert, hinzugefügt oder entfernt wurden.
Content API for Shopping | Merchant API | Beschreibung |
---|---|---|
id |
name |
Die primäre Kennung für ein Produkt ist jetzt die REST-Ressource name . |
Attribute der Produktdatenspezifikation auf höchster Ebene (z.B. title , price , link ) |
productAttributes Objekt |
Produktattribute wie title , price und link sind nicht mehr Felder der obersten Ebene. Sie sind jetzt sowohl in den Ressourcen Product als auch ProductInput im Objekt productAttributes gruppiert. So erhalten Sie eine übersichtlichere und besser organisierte Ressourcenstruktur. |
targetCountry |
feedLabel |
Der Ressourcenname verwendet jetzt feedLabel anstelle von targetCountry , um der Merchant Center-Funktionalität zu entsprechen. |
feedId |
dataSource (Abfrageparameter) |
Der Name dataSource ist jetzt ein erforderlicher Abfrageparameter für alle productInputs -Schreibmethoden (insert , update , delete ). |
channel |
Nicht verfügbar. Verwenden Sie legacy_local nur für lokal erhältliche Produkte. |
Das Feld „channel “ ist in der Merchant API nicht mehr vorhanden. Bei Produkten mit dem Kanal LOCAL in der Content API for Shopping sollte stattdessen das Feld legacy_local auf „true“ gesetzt werden. |
Nicht verfügbar | versionNumber |
Ein neues optionales Feld für ProductInput , mit dem verhindert werden kann, dass Daten in primäre Datenquellen in falscher Reihenfolge eingefügt werden. |
string -Felder mit definiertem Satz von Werten |
enum -Felder mit definiertem Satz von Werten |
Felder in Produktattributen mit einem definierten Satz von Werten (z. B. excluded_destinations , availability ) haben jetzt den Typ enum . |