微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

获取CANNOT_PURCHASE获取action.type.DigitalPurchaseCheckResult以获取受支持的区域设置英文和已启用的Access Play购买应用

如何解决获取CANNOT_PURCHASE获取action.type.DigitalPurchaseCheckResult以获取受支持的区域设置英文和已启用的Access Play购买应用

获取CANNOT_PURCHASE获取action.type.DigitalPurchaseCheckResult以获取支持的语言环境(英文)和已启用的Access Play购买应用

场景:

  1. 操作控制台>目录信息>其他信息>您的操作是否使用Digital Purchase API执行数字商品交易? -是:

  2. 操作控制台>品牌验证:

  • 网站:关联的网站(https://my_website.com/)
  • Android应用:我的应用,com.mycompany.app,状态-已连接,访问Play购买-已启用
  1. 操作控制台>场景> DigitalPurchaseCheck已根据documentation

    完成
  2. 调用将DigitalPurchaseCheck场景用作过渡。

  3. 调用测试应用程序和处理“ if scene.slots.status ==“ FINAL” && session.params.DigitalPurchaseCheck.resultType ==“ CAN_PUR​​CHASE”“条件的Webhook永远不会被调用。而是调用处理“ else if scene.slots.status ==“ FINAL””的webhook。

  4. 在DigitalPurchaseCheck验证期间收到的webhookRequest如下所示:

{
  "requestJson": {
    "handler": {
      "name": "cannotPurchaseHandler"
    },"intent": {
      "name": "","params": {
        "DigitalPurchaseCheck": {
          "original": "","resolved": {
            "resultType": "CANNOT_PURCHASE","@type": "type.googleapis.com/google.actions.transactions.v3.DigitalPurchaseCheckResult"
          }
        }
      },"query": ""
    },"scene": {
      "name": "DigitalPurchaseCheck","slotFillingStatus": "FINAL","slots": {
        "DigitalPurchaseCheck": {
          "mode": "required","status": "SLOT_UNSPECIFIED","value": {
            "resultType": "CANNOT_PURCHASE","@type": "type.googleapis.com/google.actions.transactions.v3.DigitalPurchaseCheckResult"
          },"updated": true
        }
      }
    },"session": {
      "id": "ABwppHHCRgAM0p9S2851n8Z02SreJqDQPeP1dS5qeX6ywHjLEKz0ZTOZqch4uNNaOhTORcqlWXgGSa31Nq3zxJ0mAYE","params": {
        "DigitalPurchaseCheck": {
          "resultType": "CANNOT_PURCHASE","@type": "type.googleapis.com/google.actions.transactions.v3.DigitalPurchaseCheckResult"
        }
      },"typeOverrides": [],"languageCode": ""
    },"user": {
      "locale": "en-US","params": {
        "tokenPayload": {...}

您会看到该语言环境支持数字交易:"locale": "en-US",但结果始终是:"resultType": "CANNOT_PURCHASE"

文档中包含有趣的注释:“ 2。a。验证交易要求:在允许用户进行购买之前,确保用户帐户已设置为执行交易是一种很好的做法。此步骤包括检查用户是否已配置了付款方式,并且他们位于支持数字交易的语言环境中。为此,您应该过渡到执行数字购买检查的场景。 “

因此,就我而言,第二个条件已经满足:它们位于支持数字交易的语言环境中

但是,第一种情况(检查用户是否配置了付款方式)可能会导致验证失败。我正在使用开发者帐户进行测试。但是文档中没有提及应配置为测试事务流的其他任何内容

在模拟器和真实设备(如Home Mini,nest Hub,Android上的Google Assistant)中进行了测试。

请您帮忙!

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。