HttpError 400 Bad Request - Google Admin Directory API(Python)

时间:2015-01-20 17:31:22

标签: python api sdk directory admin

我在创建Google项目即服务帐户方面遇到了困难。我在Python中使用Admin SDK,特别是Directory API。我相信我正确地进行了身份验证,但是当涉及到调用users.list时,我收到以下错误:

Traceback (most recent call last):
  File "googleproject.py", line 17, in <module>
userlist = service.users().list().execute(http = http_auth)
  File "/usr/local/lib/python2.7/dist-packages/oauth2client/util.py", line 135, in positional_wrapper
return wrapped(*args, **kwargs)
  File "/usr/local/lib/python2.7/dist-packages/googleapiclient/http.py", line 723, in execute
raise HttpError(resp, content, uri=self.uri)
googleapiclient.errors.HttpError: <HttpError 400 when requesting https://www.googleapis.com/admin/directory/v1/users?alt=json returned "Bad Request">

我的代码如下:

from oauth2client.client import SignedJwtAssertionCredentials
from httplib2 import Http
from apiclient.discovery import build

#----AUTHORISATION----#

client_email = '*****@developer.gserviceaccount.com'
with open('*****.p12') as f:
  private_key = f.read()

credentials = SignedJwtAssertionCredentials(client_email, private_key, 'https://www.googleapis.com/auth/admin.directory.user')
http_auth = credentials.authorize(Http())

#--------------------#

service = build('admin', 'directory_v1', http = http_auth)
userlist = service.users().list().execute(http = http_auth)

我已尝试将http = http_auth作为参数传递给execute()。我基本上遵循了这里给出的例子:https://code.google.com/p/google-api-python-client/source/browse/samples/service_account/tasks.py

我在开发者控制台中启用了Admin SDK,并在Google Apps控制台中添加了客户端ID和范围。

1 个答案:

答案 0 :(得分:6)

我设法解决了!问题是我没有在list参数中设置域。所以新代码如下:

from oauth2client.client import SignedJwtAssertionCredentials
from httplib2 import Http
from apiclient.discovery import build

#----AUTHORISATION----#

client_email = '*****@developer.gserviceaccount.com'
with open('*****') as f:
  private_key = f.read()

credentials = SignedJwtAssertionCredentials(client_email, private_key, 'https://www.googleapis.com/auth/admin.directory.user', sub = 'super-admin@domain.com')
http_auth = credentials.authorize(Http())

#--------------------#

service = build('admin', 'directory_v1', http = http_auth)
user = service.users().list(showDeleted = False, domain = 'domain.com').execute()