我注意到,我使用SoundcloudPHP编写的某些代码今天停止了身份验证,尽管几天前我上次使用它时,它仍能正常工作。为了解决这个问题,我一直在尝试使用/ oauth2 / token端点进行身份验证,但响应一直是401并且为空。我一直在使用https://developers.soundcloud.com/docs/api/reference#token页面上的curl
从命令行:
curl -v -X POST "https://api.soundcloud.com/oauth2/token" -F 'client_id=MY_ID' -F 'client_secret=MY_SECRET' -F 'grant_type=authorization_code' -F 'redirect_uri=MY_REDIRECT' -F 'code=0000000EYAA1CRGodSoKJ9WsdhqVQr3g'
响应:
* About to connect() to api.soundcloud.com port 443 (#0)
* Trying 72.21.91.127... connected
* Connected to api.soundcloud.com (72.21.91.127) port 443 (#0)
* successfully set certificate verify locations:
* CAfile: none
CApath: /etc/ssl/certs
* 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 AES256-SHA
* Server certificate:
* subject: OU=Domain Control Validated; CN=*.soundcloud.com
* start date: 2014-04-22 16:52:12 GMT
* expire date: 2016-04-08 10:08:48 GMT
* subjectAltName: api.soundcloud.com matched
* issuer: C=BE; O=GlobalSign nv-sa; CN=GlobalSign Domain Validation CA - SHA256 - G2
* SSL certificate verify ok.
> POST /oauth2/token HTTP/1.1
> User-Agent: curl/7.19.7 (x86_64-pc-linux-gnu) libcurl/7.19.7 OpenSSL/0.9.8k zlib/1.2.3.3 libidn/1.15
> Host: api.soundcloud.com
> Accept: */*
> Content-Length: 658
> Expect: 100-continue
> Content-Type: multipart/form-data; boundary=----------------------------e695cc6c8133
>
< HTTP/1.1 100 Continue
< HTTP/1.1 401 Unauthorized
< Access-Control-Allow-Headers: Accept, Authorization, Content-Type, Origin
< Access-Control-Allow-Methods: GET, PUT, POST, DELETE
< Access-Control-Allow-Origin: *
< Access-Control-Expose-Headers: Date
< Cache-Control: private, max-age=0, must-revalidate
< Date: Thu, 01 Oct 2015 23:25:25 GMT
< Server: am/2
< Content-Length: 0
<
* Connection #0 to host api.soundcloud.com left intact
* Closing connection #0
* SSLv3, TLS alert, Client hello (1):
我创建了新的客户端标签,看它们是否可以工作,并且得到了相同的结果。由于我使用的是文档中提供的curl,因此我希望它能正常工作。有任何想法吗?
我是php https://github.com/njasm/soundcloud库的创建者。
它的用户报告了同样的问题,实际上您说的也是如此,因为SoundCloud上的curl示例现在不再起作用(出于某些奇怪的原因)。研究修复库的问题,我发现了似乎是内容类型的问题。
似乎在请求/刷新令牌时必须使用的内容类型必须始终为application / x-form-urlencoded,并且在我们(库)通过与application / json的内容类型进行通信之前可以正常使用。
如果您是我的图书馆的用户,则应更新到最新的母版。如果您可以帮助测试该修补程序,请返回至问题页面https://github.com/njasm/soundcloud/issues/25
更新:确认内容类型必须为application / x-form-urlencoded
我正在进行一些测试,以确认确实是这种情况。如果是这样,我将提交标记为稳定版本。
祝你好运,希望这能帮到你!
本文收集自互联网,转载请注明来源。
如有侵权,请联系 [email protected] 删除。
我来说两句