当前位置: 首页 > 知识库问答 >
问题:

Google Admin SDK 403未授权访问此资源/API

隆钊
2023-03-14

null

GoogleCredential credential = GoogleCredential.fromStream(Util.class.getResourceAsStream("[credential_file].json")).createScoped(SCOPES);

Directory directory = new Directory.Builder(httpTransport, JSON_FACTORY, credential).build();

Directory.Members dirMem = directory.members();
Members members = dirMem.list("[group_email]").execute();

这导致最后一行(codeDirmem.list/code...)出现异常403(未授权访问此资源/API)。

从文档(https://developers.google.com/admin-sdk/directory/v1/guides/delegation)和其他文章中,我看到解决方案是用 设置一个服务帐户用户。但是,这意味着我必须使用p12文件而不是json文件(Google建议您在创建密钥时使用json文件)。

有没有办法在仍然使用json文件的情况下绕过这个问题(它也涉及更少的代码)。

null

共有3个答案

谭鹏云
2023-03-14

由于不支持JSON凭据serviceAccountUser,我已经做了一个解决办法:制作凭据副本。

参见此处代码:https://stackoverflow.com/A/42313446/548473

艾骏
2023-03-14

现在,我只使用这里概述的p12文件:

https://developers.google.com/admin-sdk/directory/v1/guides/development

如果有人知道用json文件执行这个问题中的代码的方法,请随时提供comment/answer。

宇文金鑫
2023-03-14

null

 类似资料:
  • 我在使用PHP api实际版本的示例时遇到了一个问题,并且使用了examples文件夹的“service-account.PHP”文件。 null null 以下是错误堆栈: null null

  • 问题内容: 我仅在使用PHP api实际版本的示例并使用examples文件夹的“ service-account.php”文件时遇到问题。 原来是用于显示“ Books API”的,并且通过我的个人凭据配置可以很好地工作,但是在我的xcase中,我需要通过directory.groups.get服务进行访问,以获取Google网上论坛邮件列表的会员帐户列表,所以我在其中更改了原始代码: 无论我做

  • 我正在使用Checkmarx安全工具扫描我的代码,它说当我对数据库执行executeUpdate()命令时,这是“不正确的资源访问授权”。 各种谷歌搜索都没有成功。

  • 我试图在我的API中向一个endpoint发出请求,然而,每次试图访问执行器endpoint都会返回401错误,访问这个资源需要完全身份验证。我只是使用spring security对用户的密码进行加密,然后再将它们存储到数据库中。我已经检查了所有类似的问题,并执行了他们给出的所有解决方案,但仍然没有运气。 securityconfig.java userService.java

  • 问题内容: 我正在使用Checkmarx安全工具来扫描我的代码,这就是说,当我对数据库执行executeUpdate()命令时,即为“不正确的资源访问授权”。 各种谷歌搜索没有成功。 问题答案: 添加一些执行访问控制检查的代码,这些代码使用诸如“ admin ”,“ authoriz ”或“ allowed ”之类的词