大家干杯,我们一直在深入阅读关于从谷歌交换 access_token 的谷歌文档,以便我们的(delphi)桌面应用程序从服务器端与谷歌进行 SSO。这是我们首先发送的有效载荷,如下所示:
通常在此之后它会重定向我登录到我们的测试用户,然后根据文档我们向端点令牌发送 POST 请求以获取 access_token 和 refresh_token ...:'https://oauth2.googleapis .com/token 使用以下参数,生成“代码”,我们也将其发送如下:
client_id=1000217514248-t1lojs6f8ed7l9ocrpbm98leahtum8n1.apps.googleusercontent.com
grant_type=authorization_code
client_secret=******
code= 4/1AY0e-g4GlavO38PI5Oo3vq04Pc4lMWN77et-02UiVWOsT-IyRQnU1lq19qo
redirect_uri = urn:ietf:wg:oauth:2.0:oob
回应总是
{
"error_description": "Missing code verifier.",
"error": "invalid_grant"
}
我们也尝试发送客户端秘密 ID,这与我们的 code_challenge 有关系吗?端点 url 和初始 url 好吗?我们缺少什么?我们使用 CEF4Delphi 作为“类似浏览器的体验,以便用户输入他们的谷歌凭据。我们一直在阅读:https ://developers.google.com/identity/protocols/oauth2/web-server#offline 我们是还尝试了操场:https ://developers.google.com/oauthplayground/ 我们在生成“代码”的 chrome 中发送初始 url,在操场中我们插入了代码,但仍然得到相同的缺少代码的错误验证者。
多谢你们