在这种与 Merchant API 交互的方法中,您通常通过 HTTP(S) 直接向 API 端点发出原始请求。您需要手动处理请求正文的构成、标头的设置(包括身份验证)以及响应的解析等各个方面。
第 1 步:注册为开发者
如需使用 Merchant API,您必须注册开发者联系信息。
注册可实现以下目的:
- 通过向用户分配
API developer角色,为您的 Merchant Center 账号创建技术联系人。这样,Google 就可以专门针对 API 和开发者正在使用的功能发送重要更新,例如服务公告和有关新功能的信息,这些信息可能对非开发者不太重要。 - 让您能够处理多个商家账号,而无需多次注册。注册时,用于向 Merchant API 进行身份验证的 Google Cloud 项目 ID 会与您的 Merchant Center 账号(其中包含技术联系人,即
API developer)相关联。这样,只要使用注册的 Google Cloud 项目进行身份验证,您就可以获取您管理的所有商家账号的重要更新。
注册时,请遵守 注册中详述的前提条件和限制。
如需使用
developerRegistration.registerGcp
方法进行注册,您可以从以下示例开始,将 {DEVELOPER_EMAIL} 替换为
相应的电子邮件地址。
POST https://merchantapi.googleapis.com/accounts/v1/accounts/{ACCOUNT_ID}/developerRegistration:registerGcp
{
"developerEmail": "{DEVELOPER_EMAIL}"
}
调用成功后,系统会返回 DeveloperRegistration 资源,以确认您的项目与账号之间的关联。
{
"name": "accounts/{ACCOUNT_ID}/developerRegistration",
"gcpIds": [
"123456789012345"
]
}
第 2 步:管理开发者联系人和权限
注册时:
- 如果电子邮件地址属于 Merchant Center 账号中的用户,则该用户会被授予
API_DEVELOPER角色。 - 如果电子邮件地址不属于现有用户,系统会向该地址发送邀请。收件人必须接受邀请,才能以
API_DEVELOPER角色添加为新用户。
首次注册后,我们建议您添加多位开发者,并向他们授予其他访问权限。
第 2a 步:授予其他权限
您需要具有 API_DEVELOPER 角色才能接收重要通知,但该角色在 Merchant Center 中的权限非常有限。如需允许此用户进行其他 API 调用或在 Merchant Center 界面中管理设置,您需要向其授予其他角色,例如 STANDARD 或 ADMIN。如需了解详情,请参阅
访问类型。
您可以使用
accounts.users.patch
方法更新用户的访问权限。
以下示例展示了如何更新用户,以向其授予 ADMIN 和 API_DEVELOPER 角色。这样,他们就可以完全管理账号,并且还会收到与 API 相关的通信。
PATCH https://merchantapi.googleapis.com/accounts/v1/accounts/{ACCOUNT_ID}/users/{DEVELOPER_EMAIL}?update_mask=access_rights
{
"access_rights": [
"ADMIN",
"API_DEVELOPER"
]
}
第 2b 步:添加备用开发者
为防止主要开发者联系人离开贵组织后 API 访问权限中断,您应至少添加一位备用开发者。
您可以使用
accounts.users.create
方法添加用户,也可以使用
accounts.users.patch
方法更新用户。我们建议您向此用户授予 ADMIN 和 API_DEVELOPER 角色。
第 3 步:创建主要商品数据源
如需插入商品,您需要一个主要商品数据源。以下请求展示了如何创建可用于向账号插入商品的数据源:
POST https://merchantapi.googleapis.com/datasources/v1/accounts/{ACCOUNT_ID}/dataSources
{
"primaryProductDataSource": {
"contentLanguage": "en",
"countries": [
"US"
],
"feedLabel": "US"
},
"name": "primary-data-source",
"displayName": "Primary Products Data Source"
}
将 {ACCOUNT_ID} 替换为您创建的 Merchant Center 账号的 ID。
成功运行此请求后,您应该会看到以下响应:
{
"name": "accounts/{ACCOUNT_ID}/dataSources/{DATASOURCE_ID}",
"dataSourceId": "{DATASOURCE_ID}",
"displayName": "Primary Products Data Source",
"primaryProductDataSource": {
"feedLabel": "US",
"contentLanguage": "en",
"countries": [
"US"
],
"defaultRule": {
"takeFromDataSources": [
{
"self": true
}
]
}
},
"input": "API"
}
复制 name 字段的值。您将需要它来插入商品。
您可以在 Merchant Center 界面中查看此数据源。如需了解详情, 请参阅 如何找到“数据源”标签页。
第 4 步:插入商品
创建数据源后,尝试向其中插入产品。运行以下命令,并提供正确的 ACCOUNT_ID。将 {DATASOURCE_NAME} 替换为您之前复制的值。
POST https://merchantapi.googleapis.com/products/v1/accounts/{ACCOUNT_ID}/productInputs:insert?dataSource={DATASOURCE_NAME}
{
"contentLanguage": "en",
"feedLabel": "US",
"name": "Red T-shirt",
"productAttributes": {
"gender": "MALE",
"brand": "New brand"
},
"offerId": "tshirt-123"
}
成功运行此请求后,您应该会看到以下响应:
{
"name": "accounts/{ACCOUNT_ID}/productInputs/en~US~tshirt-123",
"product": "accounts/{ACCOUNT_ID}/products/en~US~tshirt-123",
"offerId": "tshirt-123",
"contentLanguage": "en",
"feedLabel": "US",
"productAttributes": {
"brand": "New brand",
"gender": "MALE"
}
}
新创建的商品的商品 ID 为 en~US~tshirt-123。您可以使用
the
accounts.products.get
方法检索有关此产品的详细信息。您还可以使用 Merchant Center 界面查看此商品。如需详细了解如何查看商品
数据,请参阅
Merchant Center 中的商品概览。