创建视频流。通过视频流,您可以将视频发送到 YouTube,YouTube 随后可将视频播送给您的观众。
常见使用场景
请求
HTTP 请求
POST https://www.googleapis.com/youtube/v3/liveStreams
授权
此请求需要获得以下至少一个范围的授权(详细了解身份验证和授权)。
范围 |
---|
https://www.googleapis.com/auth/youtube |
https://www.googleapis.com/auth/youtube.force-ssl |
参数
下表列出了此查询支持的参数。列出的所有参数都是查询参数。
参数 | ||
---|---|---|
必需参数 | ||
part |
string part 参数在此操作中有两种用途。它标识了写入操作要设置的属性,以及 API 响应将包含的属性。您可以在参数值中包含的 part 属性包括 id 、snippet 、cdn 、contentDetails 和 status 。 |
|
可选参数 | ||
onBehalfOfContentOwner |
string 此参数只能在正确授权的请求中使用。注意:此参数仅适用于 YouTube 内容合作伙伴。 onBehalfOfContentOwner 参数用于指明该请求的授权凭据会标识代表参数值中指定的内容所有者执行操作的 YouTube 内容管理系统用户。此参数适用于拥有和管理众多不同 YouTube 频道的 YouTube 内容合作伙伴。它可让内容所有者在一次身份验证后获得访问其所有视频和频道数据的权限,而无需为每个频道提供身份验证凭据。用户进行身份验证时所用的 CMS 账号必须与指定的 YouTube 内容所有者相关联。 |
|
onBehalfOfContentOwnerChannel |
string 此参数只能在正确授权的请求中使用。此参数只能在正确授权的请求中使用。注意:此参数仅适用于 YouTube 内容合作伙伴。 onBehalfOfContentOwnerChannel 参数用于指定要添加视频的频道的 YouTube 频道 ID。当请求为 onBehalfOfContentOwner 形参指定值时,此形参是必需项,并且只能与形参结合使用。此外,该请求还必须通过与 onBehalfOfContentOwner 参数指定的内容所有者相关联的 CMS 账号进行授权。最后,onBehalfOfContentOwnerChannel 参数值指定的频道必须与 onBehalfOfContentOwner 参数指定的内容所有者相关联。此参数适用于拥有和管理许多不同 YouTube 频道的 YouTube 内容合作伙伴。这样一来,内容所有者只需进行一次身份验证,即可代表参数值中指定的频道执行操作,而无需为每个单独的频道提供身份验证凭据。 |
请求正文
在请求正文中提供 liveStream 资源。 针对该资源:
-
您必须为以下属性指定一个值:
snippet.title
cdn.frameRate
cdn.ingestionType
cdn.resolution
-
您可以为以下属性设置值:
snippet.title
snippet.description
cdn.frameRate
cdn.ingestionType
cdn.resolution
contentDetails.isReusable
响应
如果成功,此方法会在响应正文中返回 liveStream 资源。
错误
下表列出了 API 在响应对此方法的调用时可能会返回的错误消息。如需了解详情,请参阅错误消息文档。
错误类型 | 错误详情 | 说明 |
---|---|---|
insufficientPermissions |
insufficientLivePermissions |
此请求无权创建指定的直播。 |
insufficientPermissions |
livePermissionBlocked |
授权请求的用户目前无法在 YouTube 上直播视频。用户的频道设置(网址为 https://www.youtube.com/features)中会提供关于用户无法直播视频的原因的详细信息。 |
insufficientPermissions |
liveStreamingNotEnabled |
向请求授权的用户未启用在 YouTube 上直播视频的权限。用户可以访问 https://www.youtube.com/features 了解详情。 |
invalidValue (400) |
invalidDescription |
liveStream 资源中的 snippet.description 属性的值最多可包含 10,000 个字符。 |
invalidValue (400) |
invalidFormat |
liveStream 资源中的 cdn.format 属性值无效。 |
invalidValue (400) |
invalidFrameRate |
liveStream 资源中的 cdn.frameRate 属性的值无效。 |
invalidValue (400) |
invalidIngestionType |
liveStream 资源中的 cdn.ingestionType 属性的值无效。 |
invalidValue (400) |
invalidResolution |
liveStream 资源中的 cdn.resolution 属性的值无效。 |
invalidValue (400) |
invalidTitle |
liveStream 资源中 snippet.title 属性的值的长度必须介于 1 到 128 个字符之间。 |
rateLimitExceeded |
userRequestsExceedRateLimit |
用户在指定时间范围内发送的请求过多。 |
required (400) |
cdnRequired |
liveStream 资源必须包含 cdn 对象。 |
required (400) |
frameRateRequired |
如果您为 cdn.resolution 属性指定了值,但未为 cdn.frameRate 属性指定值,则 API 会返回此错误。 |
required (400) |
ingestionTypeRequired |
liveStream 资源必须为 cdn.ingestionType 属性指定一个值。 |
required (400) |
resolutionRequired |
如果您为 cdn.frameRate 属性指定了值,但未为 cdn.resolution 属性指定值,则 API 会返回此错误。 |
required (400) |
titleRequired |
liveStream 资源必须为 snippet.title 属性指定一个值。 |
试试看!
使用 APIs Explorer 调用此 API 并查看 API 请求和响应。