本頁說明第三方應用程式開發人員如何使用問題解決服務,為商家建立應用程式內診斷頁面。
您可以使用帳戶 API 查看影響商家帳戶的問題,以及您有權存取的任何帳戶。
你有責任遵守購物廣告和免費產品資訊政策。如果發現有內容或行為違反這些政策,Google 購物保留採取適當處置的權利。
你可以使用這項服務建立類似 Merchant Center 帳戶診斷和產品問題頁面的 UI。
問題解決服務僅適用於第三方 UI。商家與應用程式的 UI 互動時,應觸發要求。如要自動診斷自己的商家帳戶,請參閱帳戶問題指南。
建議您在應用程式中提供下列頁面,協助商家排解問題:
- 帳戶診斷
- 產品診斷
實作診斷頁面的不同選項
您可以透過不同方式實作診斷頁面。根據需求選擇選項,決定如何處理複雜的診斷動作。您可以在要求中將 user_input_action_option 設為下列其中一個選項:
- REDIRECT_TO_MERCHANT_CENTER:這是預設選項。應用程式尚未完全實作需要顯示額外內容或接收商家額外輸入內容的動作。對於這類動作,API 會提供連結,將商家重新導向至 Merchant Center 中的相應頁面,讓商家執行動作。
- BUILT_IN_USER_INPUT_ACTIONS:您可以將需要使用者輸入內容的複雜動作,實作為應用程式內的解決方案。
實作診斷頁面
本節說明如何導入診斷頁面。系統會使用預設 (簡單) 選項處理複雜動作,例如重新導向至 Merchant Center。
如要透過應用程式內動作進行更進階的實作,請參閱下列章節,並參閱「實作內建動作並接收使用者輸入內容」。
導入作業
建議診斷頁面的流程如下:
- 商家在應用程式中開啟診斷頁面。
- 您的應用程式會呼叫 issueresolution服務,要求進行診斷。
以下是範例要求:
POST  https://merchantapi.googleapis.com/issueresolution/v1/accounts/{ACCOUNT_ID}:renderaccountissues?timeZone=America/Los_Angeles&languageCode=en-GB { }
將 {ACCOUNT_ID} 替換為要觸發動作處理程序的帳戶專屬 ID。
- 應用程式會根據對商家回應的內容,顯示診斷結果和建議採取的行動。回覆範例如下: - { "renderedIssues": [ { "title": "Misrepresentation", "impact": { "message": "Prevents all products from showing in all countries", "severity": "ERROR", "breakdowns": [ { "regions": [ { "code": "001", "name": "All countries" } ], "details": [ "Products not showing organically" ] } ] }, "prerenderedContent": "\u003cdiv class=\"issue-detail\"\u003e\u003cdiv class=\"issue-content\"\u003e\u003cp class=\"content-element\"\u003e\u003cspan class=\"segment\"\u003eBased on the information available about your business, there is reason to believe that customers are being misled on Google. Review the Misrepresentation policy and make changes to your Merchant Center and/or online store.u003c/span\u003e\u003c/p\u003e\u003cp class=\"content-element root-causes-intro\"\u003e\u003cspan class=\"segment\"\u003eMake sure your Merchant Center and online store follow the following best practices / guidelines\u003c/span\u003e\u003c/p\u003e\u003cul class=\"content-element root-causes\"\u003e\u003cli\u003e\u003cp\u003e\u003cspan class=\"segment\"\u003eProvide transparency about your business identity, business model, policies and how your customers can interact with you\u003c/span\u003e\u003c/p\u003e\u003c/li\u003e\u003cli\u003e\u003cp\u003e\u003cspan class=\"segment\"\u003ePromote your online reputation by showing reviews or highlighting any badges or seals of approval\u003c/span\u003e\u003c/p\u003e\u003c/li\u003e\u003cli\u003e\u003cp class=\"tooltip tooltip-style-info\"\u003e\u003cspan class=\"segment\"\u003eUse a professional design for your online store that includes an SSL certificate\u003c/span\u003e\u003cspan class=\"tooltip-icon\"\u003e\u003cbr\u003e\u003c/span\u003e\u003cspan class=\"tooltip-text\"\u003e\u003cspan class=\"segment\"\u003eMake sure it's accessible for all users without any redirects and doesn't have any placeholders for text and images.u003c/span\u003e\u003c/span\u003e\u003c/p\u003e\u003c/li\u003e\u003cli\u003e\u003cp class=\"tooltip tooltip-style-info\"\u003e\u003cspan class=\"segment\"\u003eProvide information in the business information settings in your Merchant Center\u003c/span\u003e\u003cspan class=\"tooltip-icon\"\u003e\u003cbr\u003e\u003c/span\u003e\u003cspan class=\"tooltip-text\"\u003e\u003cspan class=\"segment\"\u003eLink any relevant third-party platforms to your Merchant Center and create a Google Business Profile.u003c/span\u003e\u003c/span\u003e\u003c/p\u003e\u003c/li\u003e\u003cli\u003e\u003cp\u003e\u003cspan class=\"segment\"\u003eFollow SEO guidelines, improve your eligibility for seller ratings and match your product data in your Merchant Center with your online store\u003c/span\u003e\u003c/p\u003e\u003c/li\u003e\u003c/ul\u003e\u003ca href=\"https://support.google.com/merchants/answer/6150127?hl=en-US\" class=\"content-element\"\u003eLearn more about the Misrepresentation policy\u003c/a\u003e\u003c/div\u003e\u003c/div\u003e", "actions": [ { "externalAction": { "type": "REVIEW_ACCOUNT_ISSUE_IN_MERCHANT_CENTER", "uri": "https://merchants.google.com/mc/products/diagnostics/accountissues?a=672911686&hl=en-US" }, "buttonLabel": "Request review", "isAvailable": true } ], "prerenderedOutOfCourtDisputeSettlement": "\u003cdetails class=\"ods-section\"\u003e\u003csummary\u003eShow additional options available to you\u003c/summary\u003e\u003cp class=\"ods-description\"\u003e\u003cspan class=\"segment\"\u003eYou may have the option to request an external appeal. You'll also be asked to provide your routing and reference IDs.\u003c/span\u003e \u003ca href=\"https://support.google.com/european-union-digital-services-act-redress-options?hl=en-GB\" target=\"_blank\" class=\"segment\"\u003eLearn more about external appeals\u003c/a\u003e\u003c/p\u003e\u003cp class=\"ods-param ods-routing-id\"\u003e\u003cspan class=\"segment ods-param-header\"\u003eRouting ID:\u003c/span\u003e \u003cspan class=\"segment ods-param-value\"\u003eRDAX\u003c/span\u003e\u003c/p\u003e\u003cp class=\"ods-param ods-reference-id\"\u003e\u003cspan class=\"segment ods-param-header\"\u003eReference ID:\u003c/span\u003e \u003cspan class=\"segment ods-param-value\"\u003e672911686\u003c/span\u003e\u003c/p\u003e\u003c/details\u003e" }, { "title": "Adult-oriented content", "impact": { "message": "Prevents all products from showing in all countries", "severity": "ERROR", "breakdowns": [ { "regions": [ { "code": "001", "name": "All countries" } ], "details": [ "Products not showing organically" ] } ] }, "prerenderedContent": "\u003cdiv class=\"issue-detail\"\u003e\u003cdiv class=\"callout-banners\"\u003e\u003cdiv class=\"callout-banner callout-banner-info\"\u003e\u003cp\u003e\u003cspan class=\"segment\"\u003eReview requested on Aug 9, 2023. It can take a few days to complete.u003c/span\u003e\u003c/p\u003e\u003c/div\u003e\u003c/div\u003e\u003cdiv class=\"issue-content\"\u003e\u003cp class=\"content-element\"\u003e\u003cspan class=\"segment\"\u003eThere was a problem identified with the sale of prohibited adult products on your online store. In the case that you are intentionally selling adult items, enable Adult content in Settings in your Merchant Center. In your product file, use the \u003c/span\u003e\u003cspan class=\"segment segment-attribute\"\u003eadult\u003c/span\u003e\u003cspan class=\"segment\"\u003e attribute for specific products.u003c/span\u003e\u003c/p\u003e\u003cp class=\"content-element root-causes-intro\"\u003e\u003cspan class=\"segment\"\u003eMake sure the products meet the policy requirements\u003c/span\u003e\u003c/p\u003e\u003cul class=\"content-element root-causes\"\u003e\u003cli\u003e\u003cp class=\"tooltip tooltip-style-info\"\u003e\u003cspan class=\"segment\"\u003eAdult oriented content may be prohibited or restricted depending on the product sold and the country it is sold\u003c/span\u003e\u003cspan class=\"tooltip-icon\"\u003e\u003cbr\u003e\u003c/span\u003e\u003cspan class=\"tooltip-text\"\u003e\u003cspan class=\"segment\"\u003eSee a full list of countries in the HelpCenter\u003c/span\u003e\u003c/span\u003e\u003c/p\u003e\u003c/li\u003e\u003cli\u003e\u003cp class=\"tooltip tooltip-style-info\"\u003e\u003cspan class=\"segment\"\u003eDon't list sexually explicit content that is intended to arouse or includes content such as text, image, audio, or video of graphic sexual acts intended to arouse\u003c/span\u003e\u003cspan class=\"tooltip-icon\"\u003e\u003cbr\u003e\u003c/span\u003e\u003cspan class=\"tooltip-text\"\u003e\u003cspan class=\"segment\"\u003eExamples: Graphic depictions of sexual acts in progress, including hardcore pornography, any type of genital, anal, or oral sexual activity; graphic depictions of masturbation or genital arousal and language explicitly referencing arousal, masturbation, cartoon porn, or hentai\u003c/span\u003e\u003c/span\u003e\u003c/p\u003e\u003c/li\u003e\u003c/ul\u003e\u003ca href=\"https://support.google.com/merchants/answer/6150138?hl=en-US#wycd-restricted-adult-content\" class=\"content-element\"\u003eLearn more about the Adult-oriented content policy\u003c/a\u003e\u003c/div\u003e\u003c/div\u003e" }, { "title": "Missing return and refund policy", "impact": { "message": "Limits visibility of all products in all countries", "severity": "ERROR", "breakdowns": [ { "regions": [ { "code": "001", "name": "All countries" } ], "details": [ "Limited visibility for products showing organically" ] } ] }, "prerenderedContent": "\u003cdiv class=\"issue-detail\"\u003e\u003cdiv class=\"issue-content\"\u003e\u003cp class=\"content-element\"\u003e\u003cspan class=\"segment\"\u003eThere was a problem identified with the return and/or refund policy of your online store. Update your return or refund policy to provide customers a transparent shopping experience.u003c/span\u003e\u003c/p\u003e\u003cp class=\"content-element root-causes-intro\"\u003e\u003cspan class=\"segment\"\u003eMake sure your products meet the Shopping policy requirements\u003c/span\u003e\u003c/p\u003e\u003cul class=\"content-element root-causes\"\u003e\u003cli\u003e\u003cp class=\"tooltip tooltip-style-info\"\u003e\u003cspan class=\"segment\"\u003eIt's available on your online store\u003c/span\u003e\u003cspan class=\"tooltip-icon\"\u003e\u003cbr\u003e\u003c/span\u003e\u003cspan class=\"tooltip-text\"\u003e\u003cspan class=\"segment\"\u003eWe recommend that you have a separate landing page for your policy and link to it from the other pages on your online store, so that it's easy to find.u003c/span\u003e\u003c/span\u003e\u003c/p\u003e\u003c/li\u003e\u003cli\u003e\u003cp class=\"tooltip tooltip-style-info\"\u003e\u003cspan class=\"segment\"\u003eIt's available in the language of the country you're selling in or in English\u003c/span\u003e\u003cspan class=\"tooltip-icon\"\u003e\u003cbr\u003e\u003c/span\u003e\u003cspan class=\"tooltip-text\"\u003e\u003cspan class=\"segment\"\u003eMake sure that the return and/or refund policy is available in the target language or in English. Ideally, users should be given the option to select the return and/or refund policy in their own language.u003c/span\u003e\u003c/span\u003e\u003c/p\u003e\u003c/li\u003e\u003cli\u003e\u003cp\u003e\u003cspan class=\"segment\"\u003eIt's accessible to everyone visiting your online store, without having to log in, sign up or enter any personal information\u003c/span\u003e\u003c/p\u003e\u003c/li\u003e\u003c/ul\u003e\u003ca href=\"https://support.google.com/merchants/answer/9158778?hl=en-US\" class=\"content-element\"\u003eLearn more about Missing return and refund policy\u003c/a\u003e\u003c/div\u003e\u003c/div\u003e", "actions": [ { "externalAction": { "type": "REVIEW_ACCOUNT_ISSUE_IN_MERCHANT_CENTER", "uri": "https://merchants.google.com/mc/products/diagnostics/accountissues?a=672911686&hl=en-US" }, "buttonLabel": "Request review", "isAvailable": true } ] } ] }
- 建議您按照系統傳回問題的順序顯示問題,並使用 - title和- impact.message。此外,我們也建議商家將指標懸停在問題標題或說明上時,顯示問題的- impact.breakdowns。
- 商家從清單中點選問題。 
- 應用程式會顯示每個問題的詳細 - impact,並提供- country、- destination、- prerendered_content、- prerendered_out_of_court_dispute_settlement和按鈕,方便商家採取- actions來解決問題。動作類型如下:- 外部動作:指向外部頁面,例如 Merchant Center,商家可以在該頁面解決問題。
- 內建簡單動作:指向應用程式中商家可解決問題的頁面。
- 內建使用者輸入動作:開啟對話方塊,商家可在其中提供必要資訊並要求執行動作。只有在要求 BUILT_IN_USER_INPUT_ACTIONS時,才能使用這類動作。
 
- 商家按照操作說明解決問題。
- 商家會在應用程式中重新載入診斷頁面。
- 應用程式會向 IssueResolution服務提交另一項要求,並顯示更新的問題清單。
您可以比較已完成應用程式顯示的資訊與 Merchant Center 的診斷頁面,驗證實作項目。
UI 模擬
以下範例說明如何在帳戶診斷頁面中顯示 renderaccountissues 回覆中的資訊。UI 中的物件會對應至模擬中的相應 API 欄位。你可以為產品問題建立類似的頁面。

填入資料後的帳戶診斷頁面如下:

設定預先轉譯的 HTML 樣式
呼叫問題解決服務後的回應會包含 prerendered_content 欄位,以及 HTML 格式的各項問題詳細資料。您可以將這段 HTML 內容直接嵌入 UI,以易讀格式顯示問題。
您可能會看到具有 new-element 類別的 HTML 元素。整合 IssueResolution 服務後,系統會將 new-element 類別套用至新增至 HTML 的元素。建議您使用 new-element 類別隱藏元素,以便在這些元素向應用程式使用者顯示前設定樣式。
以下是 prerendered_content 欄位值的範例:
<div class="issue-detail">
  <div class="callout-banners">
    <div class="callout-banner callout-banner-info"><p><span class="segment">Review requested on Aug 9, 2023. It can take a few days to complete.</span>
    </p></div>
  </div>
  <div class="issue-content"><p class="content-element"><span class="segment">There was a problem identified with the sale of prohibited adult products on your online store. In the case that you are intentionally selling adult items, enable Adult content in Settings in your Merchant Center. In your product file, use the </span><span
      class="segment segment-attribute">adult</span><span class="segment"> attribute for specific products.</span>
  </p>
    <p class="content-element root-causes-intro"><span class="segment">Make sure the products meet the policy requirements</span>
    </p>
    <ul class="content-element root-causes">
      <li><p class="tooltip tooltip-style-info"><span class="segment">Adult oriented content may be prohibited or restricted depending on the product sold and the country it is sold</span><span
          class="tooltip-icon"><br></span><span class="tooltip-text"><span class="segment">See a full list of countries in the HelpCenter</span></span>
      </p></li>
      <li><p class="tooltip tooltip-style-info"><span class="segment">Don't list sexually explicit content that is intended to arouse or includes content such as text, image, audio, or video of graphic sexual acts intended to arouse</span><span
          class="tooltip-icon"><br></span><span class="tooltip-text"><span class="segment">Examples: Graphic depictions of sexual acts in progress, including hardcore pornography, any type of genital, anal, or oral sexual activity; graphic depictions of masturbation or genital arousal and language explicitly referencing arousal, masturbation, cartoon porn, or hentai</span></span>
      </p></li>
    </ul>
    <a href="https://support.google.com/merchants/answer/6150138?hl=en-US#wycd-restricted-adult-content"
       class="content-element">Learn more about the Adult-oriented content policy</a></div>
</div>
如果您在應用程式中嵌入上述 HTML 程式碼 prerendered_content,且未套用任何樣式,則會顯示以下內容:

您可以使用多個 CSS 類別,調整內容在 UI 中的顯示方式。 以下是可使用的 CSS 範例:
issue-detail {
  text-align: left;
  width: 700px;
  border-radius: 8px;
  background: white;
  margin: 16px;
  padding: 16px;
}
.content-element {
  margin: 8px 0 8px 0;
  display: block;
}
/* callout banners */
.callout-banners {
  margin: 0 0 16px 0;
}
.callout-banner {
  display: block;
  padding: 16px 16px 6px 16px;
  margin: 0 0 8px 0;
  border-radius: 8px;
}
.callout-banner-info {
  background: #e8f0fe;
}
.callout-banner-warning {
  background: #fef7e0;
}
.callout-banner-error {
  background: #fce8e6;
}
/* add an icon to the callout banner */
.callout-banner p {
  background-repeat: no-repeat;
  padding-left: 32px;
}
.callout-banner-error p {
  background-image: url("https://fonts.gstatic.com/s/i/short-term/release/googlesymbols/error/default/20px.svg");
}
.callout-banner-warning p {
  background-image: url("https://fonts.gstatic.com/s/i/short-term/release/googlesymbols/warning/default/20px.svg");
}
.callout-banner-info p {
  background-image: url("https://fonts.gstatic.com/s/i/short-term/release/googlesymbols/search/default/20px.svg");
}
/* segments with style */
.segment-attribute {
  color: #198639;
  font-family: monospace, monospace;
}
.segment-bold {
  font-weight: bold;
}
.segment-italic {
  font-style: italic;
}
/* tooltip */
.tooltip {
  position: relative;
}
.tooltip-style-info .tooltip-icon:before {
  content: '(i)';
  font-style: normal;
  font-weight: normal;
  text-decoration: inherit;
  margin-left: 5px;
}
.tooltip-style-question .tooltip-icon:before {
  content: '(?)';
  font-style: normal;
  font-weight: normal;
  text-decoration: inherit;
  margin-left: 5px;
}
.tooltip .tooltip-text {
  visibility: hidden;
  text-align: left;
  background: white;
  border-radius: 8px;
  padding: 5px 0;
  border: 1px solid;
  padding: 10px;
  box-shadow: 3px 7px 12px #c1c1c1;
  position: absolute;
  z-index: 1;
}
.tooltip:hover .tooltip-text {
  visibility: visible;
}
/* table */
table.content-element {
  margin: 16px 0 16px 0;
  border: 1px solid #ccc;
  border-collapse: collapse;
  margin: 1em 0;
}
table.content-element th {
  background-color: #eee;
}
table.content-element th, table td {
  border: 1px solid #ddd;
  font-size: 0.9em;
  padding: 0.3em 1em;
}
/* hidde elements added in future, until they are supported in your application */
.new-element {
  visibility: hidden;
}
如果您使用上述 CSS,呈現的內容會如下所示:

您也可以使用 CSS 設定及顯示工具提示:

實作內建動作並接收使用者輸入內容
您可以使用內建動作和使用者輸入內容,在應用程式中提供複雜的診斷功能。建議您將其設為對話方塊,方便商家提供輸入內容、閱讀其他資訊,以及確認要求。
每個動作都包含一或多個動作流程。部分動作可能有多個流程。舉例來說,商家不同意審查結果而要求額外審查時,流程可能與商家已修正問題時不同。
如要要求資料,以便使用使用者輸入內容執行複雜動作,請將 user_input_action_option 欄位設為 BUILT_IN_USER_INPUT_ACTIONS 值。
POST https://merchantapi.googleapis.com/issueresolution/v1/accounts/{ACCOUNT_ID}:renderaccountissues?timeZone=America/Los_Angeles&languageCode=en-GB
{
"user_input_action_option": "BUILT_IN_USER_INPUT_ACTIONS"
}
將 {ACCOUNT_ID} 替換為要觸發動作處理程序的帳戶專屬 ID。
導入作業
以下是我們建議的診斷頁面流程,要求使用者輸入內容時應如下所示:
- 使用者點選動作按鈕。 - 如果有多個流程可用,應用程式會提供所有流程,讓使用者根據意圖選取其中一個。
- 使用者選取流程。
 
- 應用程式會顯示所選動作流程的標題、訊息、附註和使用者輸入表單。建議您在對話方塊中顯示這些詳細資料。 - 如果顯示附註,其中會包含重要資訊,協助使用者進一步瞭解動作的運作方式,以及如何順利完成動作。建議您醒目顯示這則訊息,並根據附註的嚴重程度設定樣式。
- 如果流程中有任何輸入欄位,就必須顯示這些欄位,讓使用者提供值。如果輸入欄位標示為必填,則商家必須提供值,應用程式才能傳送要求。
 
- 使用者閱讀資訊並提供要求的值。 
- 使用者點選按鈕確認要求。 
- 應用程式會呼叫問題解決服務,觸發動作處理程序。以下是範例要求: - POST https://merchantapi.googleapis.com/issueresolution/v1/accounts/{ACCOUNT_ID}:triggeraction { actionContext: "ActionContextValue=", actionInput: { actionFlowId: "flow1", inputValues: [ { input_field_id: "input1", checkbox_input_value: { value: true } } ] }- 將 {ACCOUNT_ID} 替換為要觸發動作處理程序的帳戶專屬 ID。 - 如要存取 - BuiltInUserInputAction的- triggeraction方法,請使用這份表單提出要求。
- 應用程式會顯示服務傳回的確認訊息。 - IssueResolution- 如果服務傳回 INVALID_ARGUMENT狀態的驗證錯誤,其中會包含詳細資訊和本地化錯誤訊息,應向商家顯示。建議在受影響的輸入欄位附近顯示這類錯誤。回覆範例如下:
 - { "error": { "code": 400, "message": "[actionInput.inputValues] Invalid user input", "status": "INVALID_ARGUMENT", "details": [ { "@type": "type.googleapis.com/google.rpc.ErrorInfo", "reason": "invalid", "domain": "global" }, { "@type": "type.googleapis.com/google.rpc.BadRequest", "fieldViolations": [ { "field": "actionInput.inputValues.input", "description": "The field is required" } ] } ] } }- 如果服務傳回無效狀態或內部錯誤 (以 FAILED_PRECONDITION和INTERNAL狀態表示),應用程式應指示商家重新載入頁面或稍後再試。
 
- 如果服務傳回