La risorsa products
offre molta flessibilità e controllo su più di 60 attributi di prodotto.Esistono diversi campi obbligatori che devono essere inclusi per ottenere l'approvazione per la visualizzazione su Google Shopping.
Esistono una serie di campi facoltativi che possono diventare obbligatori in base a condizioni diverse, come località, tipo di prodotto, varianti di prodotto e set di prodotti. Per ulteriori dettagli sugli oltre 60 parametri facoltativi che possono essere configurati per i prodotti, consulta le specifiche dei dati di prodotto.
La risorsa products
ti consente di insert
, get
, update
e delete
un prodotto alla volta e di list
tutti i prodotti nel database di Merchant Center.
La risorsa productstatuses
può essere utilizzata per verificare lo stato di approvazione o disapprovazione di un prodotto specifico per una destinazione. Consulta la guida allo stato dei prodotti per ulteriori dettagli su quali prodotti potrebbero presentare problemi di qualità dei dati e su quali potrebbero essere.
Nei nostri esempi di API, utilizziamo tre prodotti: due t-shirt Google e un
berretto Google. Utilizziamo un insieme minimo di dati di prodotto mostrati nella tabella di seguito per
effettuare products
chiamate alla risorsa per inserire, ricevere, aggiornare, elencare ed eliminare
singoli prodotti e gruppi di prodotti.
Ti consigliamo di configurare i dati fiscali e di spedizione a livello di account anziché a livello di prodotto.
Per i subaccount multi-venditore dei Marketplace, tutti i prodotti devono includere il campo external_seller_id
. Per ulteriori dettagli, consulta la sezione ID prodotto.
id | online:en:US:1111111111 | online:en:US:2222222222 | online:en:US:3333333333 |
---|---|---|---|
offerId | 1111111111 | 2222222222 | 3333333333 |
title | La maglietta nera Google | Maglietta verde Google | Cappello twill di Google |
descrizione | La maglietta nera Google | T-shirt Google 100% cotone | Cappello Google classico |
ID gruppo di articoli | google_tee | google_tee | |
collegare | http://my.site.com/blacktee | http://my.site.com/greentee | http://my.site.com/blackhat |
Condizione | Novità | Novità | Novità |
price | 21.99 EUR | 21.99 EUR | 10.99 EUR |
disponibilità | Disponibile | Disponibile | Disponibile |
imageLink | https://shop.example.com/ |
https://shop.example.com/ |
https://shop.example.com/ |
[gtin] | 9504000059422 | 9504000059446 | 9504000059452 |
mpn | 00638NIC | 00638ANG | ABC |
brand | |||
Categoria di prodotto Google | Abbigliamento e accessori > Abbigliamento | Abbigliamento e accessori > Abbigliamento | Abbigliamento e accessori > Accessori di abbigliamento > Cappelli |
colore | nero | green | nero |
dimensioni | L | L | L |
age_group | contenuti erotici | contenuti erotici | contenuti erotici |
genere | uomo | uomo | unisex |
included_destination | Shopping Actions, annunci Shopping | Shopping Actions, annunci Shopping | Shopping Actions |
products.insert
Per inserire un singolo prodotto, usa il seguente URL di richiesta, specificando il tuo ID commerciante e un corpo JSON di esempio. Un inserto crea il nuovo prodotto. Se esistono valori per gli attributi channel
, contentLanguage
, offerId
e feedLabel
di un determinato prodotto, questo metodo aggiorna la voce e sostituisce tutti i dati delle precedenti chiamate API per il prodotto in questione.
I prodotti esclusi da tutte le destinazioni per più di 7 giorni vengono eliminati automaticamente.
L'esempio mostrato inserisce una nuova "T-shirt Google nera" nei prodotti disponibili.
POST https://shoppingcontent.googleapis.com/content/v2.1/{merchantId}/products
Esempio di chiamata del corpo della richiesta per products.insert
:
{
"kind": "content#product",
"offerId": "1111111111",
"title": "Google Tee Black",
"description": "The Black Google Tee is available in unisex sizing.",
"link": "http://my.site.com/blacktee/",
"imageLink": "https://shop.example.com/.../images/GGOEGXXX1100.jpg",
"contentLanguage": "en",
"targetCountry": "US",
"feedLabel": "US",
"channel": "online",
"ageGroup": "adult",
"availability": "in stock",
"availabilityDate": "2019-01-25T13:00:00-08:00",
"brand": "Google",
"color": "black",
"condition": "new",
"gender": "male",
"googleProductCategory": "1604",
"gtin": "608802531656",
"itemGroupId": "google_tee",
"mpn": "608802531656",
"price": {
"value": "21.99",
"currency": "USD"
},
"sizes": [
"Large"
]
}
Un prodotto può anche avere attributi personalizzati impostati all'interno del corpo JSON. Ad esempio,
possiamo impostare un valore purchase_quantity_limit
per un singolo prodotto al fine di limitare
il numero di articoli che un cliente può ordinare:
"customAttributes": [
{
"name": "purchase_quantity_limit",
"value": "4"
}
]
Tieni presente che l'attributo personalizzato purchase_quantity_limit
imposta un limite di acquisto per ordine del cliente alla definizione di prodotto ed è supportato anche dai feed. L'attributo è attualmente in versione beta fino a quando non sarà completamente supportato dall'API. Qualsiasi attributo personalizzato aggiuntivo può essere aggiunto da un commerciante, ma non comporta un'elaborazione specifica da parte delle API.
Una chiamata riuscita restituisce un codice HTTP 200
e un corpo della risposta contenente
la risorsa di prodotto inserita con solo i campi id
, offerId
, contentLanguage
,
feedLabel
e channel
:
{
"kind": "content#product",
"id": "online:en:US:1111111111",
"offerId": "1111111111",
"contentLanguage": "en",
"targetCountry": "US",
"feedLabel": "US",
"channel": "online"
}
products.get
Per ottenere informazioni su un prodotto specifico nel database di Merchant Center, utilizza products.get
. Potrebbero essere necessari alcuni minuti prima che un prodotto appena inserito sia disponibile tramite questa chiamata.
Utilizza i seguenti parametri e URL di richiesta HTTP, il tuo ID commerciante e l'ID prodotto (formato ID REST) relativo al prodotto che vuoi ricevere:
GET https://shoppingcontent.googleapis.com/content/v2.1/{merchantId}/products/{productId}
Una chiamata riuscita restituisce un HTTP 200
e la "risorsa di prodotto" nel corpo della risposta. Di seguito sono riportati alcuni dati di prodotto di esempio recuperati da un prodotto con ID online:en:US:1111111111
:
{
"kind": "content#product",
"id": "online:en:US:1111111111",
"offerId": "1111111111",
"source": "api",
"title": "Google Tee Black",
"description": "The Black Google Tee is available in unisex sizing.",
"link": "http://my.site.com/blacktee/",
"imageLink": "https://shop.example.com/.../images/GGOEGXXX1100.jpg",
"contentLanguage": "en",
"targetCountry": "US",
"feedLabel": "US",
"channel": "online",
"ageGroup": "adult",
"availability": "in stock",
"availabilityDate": "2019-01-25T13:00:00-08:00",
"brand": "Google",
"color": "black",
"condition": "new",
"gender": "male",
"googleProductCategory": "1604",
"gtin": "608802531656",
"itemGroupId": "google_tee",
"mpn": "608802531656",
"price": {
"value": "21.99",
"currency": "USD"
},
"sizes": [
"Large"
]
}
products.update
Per aggiornare un singolo prodotto, utilizza il seguente URL di richiesta con il metodo PATCH, specificando l'ID commerciante, l'ID prodotto e un corpo JSON contenente i dati che vuoi aggiornare per il prodotto. A differenza di products.insert
, che richiede
di fornire tutti i campi applicabili, products.update
richiede solo di
specificare i campi da modificare.
Per aggiungere o modificare un attributo, specifica il campo con il nuovo valore nel corpo JSON. L'esempio mostrato aggiorna i valori title
e description
di una "T-shirt Google nera" esistente con i dati di prodotto forniti nel corpo della richiesta, lasciando tutti gli altri campi invariati.
PATCH https://shoppingcontent.googleapis.com/content/v2.1/{merchantId}/products/{productId}
Esempio di chiamata del corpo della richiesta per products.update
:
{
"title": "Google Tee Black Limited Edition",
"description": "The Limited Edition Tee is available in unisex sizing and features a retail fit."
}
Solo i campi di primo livello possono essere aggiornati tramite una richiesta products.update
.
Se vuoi aggiornare i campi nidificati, devi fornire l'intero oggetto di primo livello.
L'esempio mostrato aggiornerà l'oggetto salePrice
di primo livello, inclusi i campi nidificati di un prodotto esistente, con i dati di prodotto forniti nel corpo della richiesta, lasciando tutti gli altri campi invariati.
PATCH https://shoppingcontent.googleapis.com/content/v2.1/{merchantId}/products/{productId}
{
"salePrice": {
"value": "17.99",
"currency": "USD"
}
}
Per selezionare determinati campi da aggiornare senza apportare modifiche agli altri inclusi nel corpo della richiesta, puoi specificare un updateMask
. Questo parametro della stringa di query
deve essere un elenco separato da virgole di campi da modificare.
updateMask
è utile quando vuoi dichiarare che verranno aggiornati solo i campi denominati. Non specificare un updateMask
equivale a contrassegnare tutti i campi della richiesta da aggiornare, come mostrato nell'esempio precedente.
L'esempio mostrato aggiornerà solo i valori description
e availability
di una "T-shirt Google nera" esistente con i rispettivi dati di prodotto forniti
nel corpo della richiesta, lasciando invariati tutti gli altri campi, incluso title
.
PATCH https://shoppingcontent.googleapis.com/content/v2.1/{merchantId}/products/{productId}?updateMask=description,availability
Esempio di chiamata del corpo della richiesta per products.update
:
{
"title": "Google Tee Black",
"description": "This Limited Edition is out of print.",
"availability": "out of stock"
}
Se un campo viene specificato nell'elenco updateMask
, ma non nel corpo della richiesta, verrà eliminato dalla risorsa Product
, se esistente.
L'esempio mostrato utilizzerà updateMask
per rimuovere il valore per il campo salePrice
.
PATCH https://shoppingcontent.googleapis.com/content/v2.1/{merchantId}/products/{productId}?updateMask=salePrice
Il corpo della richiesta di esempio non deve includere il campo salePrice
per eliminarlo. Puoi anche non fornire alcun corpo o un corpo vuoto. Gli altri campi rimarranno invariati, a condizione che non vengano visualizzati in updateMask
.
Per utilizzare updateMask
in una richiesta products.custombatch
, è necessario specificare updateMask
nel corpo della richiesta.
L'esempio mostrato aggiornerà price
e availability
di una "T-shirt Google nera" esistente utilizzando products.custombatch
con i dati di prodotto forniti nella voce batch, lasciando invariati tutti gli altri campi, tra cui title
e description
.
POST https://shoppingcontent.googleapis.com/content/v2.1/products/batch
{
"entries": [{
"batchId": 1,
"merchantId": "MERCHANT_ID",
"productId": "online:en:US:1111111111",
"method": "update",
"product": {
"title": "Google Tee Black",
"description": "The Black Google Tee is available in unisex sizing.",
"availability": "in stock",
"price": {
"value": "19.99",
"currency": "USD"
}
},
"updateMask": "availability,price"
}]
}
products.delete
Per eliminare un singolo prodotto, utilizza products.delete
con l'URL della richiesta HTTP di esempio, il tuo ID commerciante e l'ID prodotto (in formato ID REST come online:en:US:1111111111
) relativo al prodotto che vuoi eliminare:
DELETE https://shoppingcontent.googleapis.com/content/v2.1/{merchantId}/products/{productId}
Una risposta corretta restituisce un HTTP Status 204
senza corpo della risposta.
products.list
products.list
elenca tutti i prodotti presenti nel database di Merchant Center. Usa il seguente URL di richiesta:
GET https://shoppingcontent.googleapis.com/content/v2.1/{merchantId}/products
Una chiamata riuscita restituisce dati HTTP 200
e JSON per i prodotti nella chiave "resources".
Vengono restituiti i seguenti tre prodotti di esempio:
{
"kind": "content#productsListResponse",
"resources": [
{
"kind": "content#product",
"id": "online:en:US:1111111111",
"offerId": "1111111111",
"source": "api",
"title": "Google Tee Black",
"description": "The Black Google Tee is available in unisex sizing.",
"link": "http://my.site.com/blacktee/",
"imageLink": "https://shop.example.com/.../images/GGOEGXXX1100.jpg",
"contentLanguage": "en",
"targetCountry": "US",
"feedLabel": "US",
"channel": "online",
"ageGroup": "adult",
"availability": "in stock",
"availabilityDate": "2019-01-25T13:00:00-08:00",
"brand": "Google",
"color": "black",
"condition": "new",
"gender": "male",
"googleProductCategory": "1604",
"gtin": "608802531656",
"itemGroupId": "google_tee",
"mpn": "608802531656",
"price": {
"value": "21.99",
"currency": "USD"
},
"sizes": [
"Large"
]
},
{
"kind": "content#product",
"id": "online:en:US:2222222222",
"offerId": "2222222222",
"source": "api",
"title": "Google Tee Green",
"description": "100% cotton jersey fabric sets this Google t-shirt above the crowd.
Features the google logo across the chest. Unisex sizing.",
"link": "http://my.site.com/greentee/",
"imageLink": "https://shop.example.com/.../images/GGOEGXXX0906.jpg",
"contentLanguage": "en",
"targetCountry": "US",
"feedLabel": "US",
"channel": "online",
"ageGroup": "adult",
"availability": "in stock",
"availabilityDate": "2019-01-25T13:00:00-08:00",
"brand": "Google",
"color": "green",
"condition": "new",
"gender": "male",
"googleProductCategory": "1604",
"gtin": "608802531649",
"itemGroupId": "google_tee",
"mpn": "608802531649",
"price": {
"value": "21.99",
"currency": "USD"
},
"sizes": [
"Medium"
]
},
{
"kind": "content#product",
"id": "online:en:US:3333333333",
"offerId": "3333333333",
"source": "api",
"title": "Google Twill Cap",
"description": "Classic urban styling distinguishes this Google cap.
Retains its shape, even when not being worn.",
"link": "http://my.site.com/blackhat/",
"imageLink": "https://shop.example.com/.../images/GGOEGHPB071610.jpg",
"contentLanguage": "en",
"targetCountry": "US",
"feedLabel": "US",
"channel": "online",
"ageGroup": "adult",
"availability": "in stock",
"availabilityDate": "2019-01-07T13:00:00-08:00",
"brand": "Google",
"color": "black",
"condition": "new",
"gender": "male",
"googleProductCategory": "173",
"gtin": "689355417246",
"mpn": "689355417246",
"price": {
"value": "10.99",
"currency": "USD"
},
"sizes": [
"Medium"
]
}
]
}