我正在使用Google API PHP客户端设置Android Management API,但我发现我发送给客户端的身份验证配置在发送请求时没有任何影响。
我测试了凭证文件是否存在以及文件中的语法错误是否得到处理。我遵循了错误消息链接。我已经在网上搜索了几次,找到了库中的文档和php doc,但无法弄清楚。
$client = new \Google_Client();
$client->setApplicationName('SecretName');
$client->setAuthConfig(x::getRootDir() . '/modules/package-androidmanagement/credentials2.json');
$client->addScope(Google_Service_AndroidManagement::ANDROIDMANAGEMENT);
$am = new \Google_Service_AndroidManagement($client);
try {
$signupUrl = $am->signupUrls->create(['projectId' => $this->projectId, 'callbackUrl' => x::getDomain()]);
} catch (Exception $exception) {
echo $exception->getMessage();
}
预期:signupUrl对象 实际:请求缺少必需的身份验证凭据。预期的OAuth 2访问令牌,登录cookie或其他有效的身份验证凭据。参见https://developers.google.com/identity/sign-in/web/devconsole-project。
答案 0 :(得分:1)
在能够生成任何组织注册网址(或执行任何api调用)之前,需要先对自己进行身份验证。
您可以通过设置重定向URL并将用户定向到注册URL来实现。
$client->setRedirectUri('https://example.com/register');
$authUrl = $client->createAuthUrl();
这需要完整地设置oauth流。这意味着您的oauth同意屏幕已由Google验证(可能需要花费数周的时间),并且您已设置了各种允许的域以用于重定向URL。
如果您仍处于开发阶段,则可以进入quickstart notebook by google提供的oauth同意屏幕:
# This is a public OAuth config, you can use it to run this guide but please use
# different credentials when building your own solution.
CLIENT_CONFIG = {
'installed': {
'client_id':'882252295571-uvkkfelq073vq73bbq9cmr0rn8bt80ee.apps.googleusercontent.com',
'client_secret': 'S2QcoBe0jxNLUoqnpeksCLxI',
'auth_uri':'https://accounts.google.com/o/oauth2/auth',
'token_uri':'https://accounts.google.com/o/oauth2/token'
}
}
SCOPES = ['https://www.googleapis.com/auth/androidmanagement']
使用它替换您的oauth json配置中的数据。
通过不设置重定向uri,它应该为您提供可以手动输入的代码。