实现 OAuth 2.0 授权

YouTube Reporting APIYouTube Analytics API 支持 OAuth 2.0 协议,用于授权访问用户的私密数据。 以下列表介绍了一些核心 OAuth 2.0 概念:

  • 当用户首次尝试使用应用中要求用户登录 Google Account or YouTube account 的功能时,应用会启动 OAuth 2.0 授权流程。

  • 您的应用会将用户定向到 Google 的授权服务器。指向该页面的链接会指定您的应用为用户账号请求访问权限的 scopescope 指定您的应用以经过身份验证的用户的身份可以检索、插入、更新或删除的资源。

  • 如果用户同意授权您的应用访问这些资源,Google 会向您的应用返回一个令牌。根据您的应用程序类型,它会验证令牌或将其换成不同类型的令牌。

    例如,服务器端 Web 应用可将返回的令牌交换为访问令牌和刷新令牌。访问令牌可让应用代表用户授权请求,刷新令牌可让应用在原始访问令牌到期时检索新的访问令牌。

重要提示:要使用 OAuth 2.0 授权,您需要在 Google API 控制台中获取授权凭据

如需了解详情,请参阅 OAuth 2.0 授权指南

OAuth 2.0 流程

Google API 支持多种 OAuth 2.0 用例:

  • 服务器端 Web 应用流程支持可安全存储持久性信息的 Web 应用。
  • JavaScript Web 应用流程支持在浏览器中运行的 JavaScript 应用。
  • 移动和桌面应用流程支持安装在设备(例如手机或计算机)上的应用。
  • 适用于电视和输入受限设备的 OAuth 2.0 流程支持输入功能有限的设备,例如游戏机和摄像头。 The YouTube Reporting and YouTube Analytics APIs do not currently support the OAuth 2.0 flow for devices.
  • 服务账号的 OAuth 2.0 流程支持不访问用户信息的服务器到服务器互动。 不过,YouTube Reporting APIYouTube Analytics API 不支持此流程。 Since there is no way to link a Service Account to a YouTube account, attempts to authorize requests with this flow will generate an error.

确定访问权限范围

有了这一范围,您不但可以让应用仅请求访问所需的资源,而且还可以让用户控制其向您的应用授予的访问权限大小。因此,请求的范围数量与获得用户同意的可能性之间可能存在反比关系。

在开始实现 OAuth 2.0 授权之前,我们建议您确定应用需要访问权限的范围。

YouTube Analytics API 使用以下范围:

Scopes
https://www.googleapis.com/auth/youtubeManage your YouTube account
https://www.googleapis.com/auth/youtube.readonlyView your YouTube account
https://www.googleapis.com/auth/youtubepartnerView and manage your assets and associated content on YouTube
https://www.googleapis.com/auth/yt-analytics-monetary.readonlyView monetary and non-monetary YouTube Analytics reports for your YouTube content
https://www.googleapis.com/auth/yt-analytics.readonlyView YouTube Analytics reports for your YouTube content

YouTube Reporting API 使用以下范围:

范围
https://www.googleapis.com/auth/yt-analytics-monetary.readonly查看您的 YouTube 内容的财务类和非财务类 YouTube Analytics 报表
https://www.googleapis.com/auth/yt-analytics.readonly查看 YouTube 分析工具为您的 YouTube 内容出具的报告

OAuth 2.0 API 范围文档包含您可能用来访问 Google API 的完整范围列表。