9

我正在开发一个使用 Google Play 新订阅功能的 android 应用程序。我的应用程序的一部分包含一个 Web 服务器,它通过 API 调用定期检查这些订阅的状态。它还取消了其中一些订阅。

Google 提供了两个 REST API 来实现这一点:

https://developers.google.com/android-publisher/v1/purchases/get

https://developers.google.com/android-publisher/v1/purchases/cancel

使用 OAuth,我可以让第一个工作得很好。但是,当我尝试取消某些订阅时,我收到一个没有详细信息的 500 错误。有没有其他人经历过这个?我使用不正确吗?我确定 OAuth 可以正常工作,因为我可以点击第一个 API。这是我的 curl 输出,隐藏了我的一些帐户数据:

curl -X POST 'https://www.googleapis.com/androidpublisher/v1/applications/com.ssd.mypkg/subscriptions/mysku/purchases/mypurchasetoken/cancel' -H 'Authorization: OAuth ya29.myoauth' -d '' -v
* About to connect() to www.googleapis.com port 443 (#0)
*   Trying 209.85.148.95... connected
* Connected to www.googleapis.com (209.85.148.95) port 443 (#0)
* SSLv3, TLS handshake, Client hello (1):
* SSLv3, TLS handshake, Server hello (2):
* SSLv3, TLS handshake, CERT (11):
* SSLv3, TLS handshake, Server finished (14):
* SSLv3, TLS handshake, Client key exchange (16):
* SSLv3, TLS change cipher, Client hello (1):
* SSLv3, TLS handshake, Finished (20):
* SSLv3, TLS change cipher, Client hello (1):
* SSLv3, TLS handshake, Finished (20):
* SSL connection using RC4-SHA
* Server certificate:
*    subject: C=US; ST=California; L=Mountain View; O=Google Inc; CN=*.googleapis.com
*    start date: 2012-06-14 06:42:53 GMT
*    expire date: 2013-06-07 19:43:27 GMT
*    subjectAltName: www.googleapis.com matched
*    issuer: C=US; O=Google Inc; CN=Google Internet Authority
*    SSL certificate verify ok.
> POST /androidpublisher/v1/applications/com.ssd.mypkg/subscriptions/mysku/purchases/mypurchasetoken/cancel HTTP/1.1
> User-Agent: curl/7.21.4 (universal-apple-darwin11.0) libcurl/7.21.4 OpenSSL/0.9.8r zlib/1.2.5
> Host: www.googleapis.com
> Accept: */*
> Authorization: OAuth ya29.myoauth
> Content-Length: 0
> Content-Type: application/x-www-form-urlencoded
> 
< HTTP/1.1 500 Internal Server Error
< Content-Type: application/json; charset=UTF-8
< Date: Fri, 06 Jul 2012 15:23:10 GMT
< Expires: Fri, 06 Jul 2012 15:23:10 GMT
< Cache-Control: private, max-age=0
< X-Content-Type-Options: nosniff
< X-Frame-Options: SAMEORIGIN
< X-XSS-Protection: 1; mode=block
< Server: GSE
< Transfer-Encoding: chunked
< 
{
 "error": {
  "code": 500,
  "message": null
 }
}
* Connection #0 to host www.googleapis.com left intact
* Closing connection #0
* SSLv3, TLS alert, Client hello (1):
4

3 回答 3

2

我可以确认有完全相同的问题。获取详细信息完美但取消失败。我正在为 Java 类使用 Google API,所以我认为这是一个普遍问题,我们应该将其作为错误发布给 google。

这是我从谷歌服务器收到的响应:

com.google.api.client.googleapis.json.GoogleJsonResponseException: 500 Internal Server Error
{
  "code" : 500,
  "message" : null
}
于 2012-07-12T20:44:34.380 回答
1

我也遇到这个错误。我的应用程序仅在 beta 测试模式下发布。我想知道这可能是问题吗?

如果相关,我正在使用googlesamples/android-play-publisher-apibasic_list_apks的修改版本,通过将服务调用定义行修改为如下所示,我将其更改为订阅撤销者:

service.purchases().subscriptions().revoke(packageName=package_name,
    subscriptionId=product_id,
    token=purchase_token)
于 2015-02-10T18:32:56.290 回答
1

我可以确认同样的问题。这是我收到的回复:

{
  "error": {
    "code": 500,
    "message": null
  }
}

我认为这个尴尬的错误消息的原因是订阅不再有效,但我们试图取消它。相反,我们应该首先检查订阅是否有效:到期日期、取消原因、自动续订。

在我的特殊情况下,订阅已过期,cancelReason1意味着它已被系统取消。

于 2016-12-26T14:25:09.300 回答