【问题标题】:ValueError: Client secrets must be for a web or installed appValueError:客户端机密必须用于 Web 或已安装的应用程序
【发布时间】:2019-10-20 01:33:39
【问题描述】:

我在 Python Quickstart 下运行 quickstart.py 示例代码,我收到以下错误:

ValueError:客户端密码必须用于 Web 或已安装的应用程序。

我创建了一个具有项目所有者权限的 credentials.json 文件。

错误发生在以下一段代码中:

if os.path.exists('token.pickle'):
    with open('token.pickle', 'rb') as token:
        creds = pickle.load(token)
# If there are no (valid) credentials available, let the user log in.
if not creds or not creds.valid:
    if creds and creds.expired and creds.refresh_token:
        creds.refresh(Request())
    else:
        flow = InstalledAppFlow.from_client_secrets_file('credentials.json', SCOPES)
        creds = flow.run_local_server()
    # Save the credentials for the next run
    with open('token.pickle', 'wb') as token:
        pickle.dump(creds, token)

我还注意到 token.pickle 文件没有被创建。这是错误输出:

  File "updateSlidev01.py", line 51, in <module>
    main()
  File "updateSlidev01.py", line 31, in main
    flow = InstalledAppFlow.from_client_secrets_file('credentials.json', SCOPES)
  File "/Library/Python/2.7/site-packages/google_auth_oauthlib/flow.py", line 174, in from_client_secrets_file
    return cls.from_client_config(client_config, scopes=scopes, **kwargs)
  File "/Library/Python/2.7/site-packages/google_auth_oauthlib/flow.py", line 147, in from_client_config
    'Client secrets must be for a web or installed app.')
ValueError: Client secrets must be for a web or installed app.

【问题讨论】:

  • 您是如何创建该 credentials.json 文件的?
  • 嗨!这正是问题所在。我回答了下面的问题。非常感谢!

标签: python google-api google-api-python-client


【解决方案1】:

问题是我使用的是在服务帐户密钥管理服务帐户下生成的 json,而不是在 OAuth 2.0 客户端 ID 下生成的那个。

【讨论】:

  • 如果 json 是作为服务帐户创建的,您可以使用什么来代替?
  • @Kajsa 谢谢你,当有人回来回答他们的问题时,总是很感激。
  • 您好-请问这是否意味着普通服务帐户不能用于此类应用程序?
【解决方案2】:

对于任何想要通过服务帐户而不是此 Oauth2 客户端 ID 实际连接到 GCP 日历 API 的人,请在原始示例中创建 creds 对象,如下所示:

from google.oauth2 import service_account

SCOPES = ['https://www.googleapis.com/auth/sqlservice.admin']
SERVICE_ACCOUNT_FILE = '/path/to/service.json'

credentials = service_account.Credentials.from_service_account_file(
        SERVICE_ACCOUNT_FILE, scopes=SCOPES)

假设服务帐户配置了正确的访问权限,这将访问日历而不提示用户确认。

【讨论】:

  • 上帝保佑你?
  • 如果我们尝试连接到 GCP 日历 API,为什么要使用“sqlservice.admin”范围?我认为您的意思是“calendar.readonly”。如果我是对的,请更正。
  • 可能 - 我认为这只是我当时碰巧使用的范围。但是,是的,显然为手头的任务使用适当的范围。
猜你喜欢
  • 2017-10-04
  • 2015-11-13
  • 2015-05-03
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2012-08-23
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多