查询频道直播流信息
接口描述
1、获取频道直播的实时推流信息
2、deployAddress、inAddress、lfr信息可能无法获取,返回值为null
3、接口支持https协议
接口URL
http://api.polyv.net/live/v3/channel/monitor/get-stream-info
请求方式
GET
接口约束
1、接口同时支持HTTP 、HTTPS ,建议使用HTTPS 确保接口安全,接口调用有频率限制,详细请查看
2、获取频道直播流信息需要频道为直播中状态
请求参数描述
示例
http://api.polyv.net/live/v3/channel/monitor/get-stream-info?appId=frlr1zazn3&sign=C467BD0B98D6CB6981EB15125C25CBA0&channelId=4184544×tamp=1692322896864
响应参数描述
data字段描述
参数名
类型
说明
deployAddress
String
推送的CDN节点IP地址
inAddress
String
推流出口IP地址
streamName
String
流名
fps
String
推流帧率
lfr
String
推流丢帧率
inBandWidth
String
推流码率,单位:bps
Java请求示例
快速接入基础代码请下载相关依赖源码, 点击下载源代码 ,下载后加入到自己的源码工程中即可。测试用例中的HttpUtil.java 和 LiveSignUtil.java 都包含在下载文件中。
强烈建议您使用直播Java SDK完成API的功能对接,直播Java SDK 对API调用逻辑、异常处理、数据签名、HTTP请求线程池进行了统一封装和优化。
private static final Logger log = LoggerFactory.getLogger(ChannelStateTest.class);
/**
* 查询频道实时推流信息
* @throws IOException
* @throws NoSuchAlgorithmException
*/
@Test
public void testGetStreamInfo() throws IOException, NoSuchAlgorithmException {
//公共参数,填写自己的实际参数
String appId = super.appId;
String appSecret = super.appSecret;
String userId = super.userId;
String timestamp = String.valueOf(System.currentTimeMillis());
//业务参数
String url = "http://api.polyv.net/live/v3/channel/monitor/get-stream-info";
String channelId = "4184544";
Map<String, String> requestMap = new HashMap<>();
requestMap.put("appId", appId);
requestMap.put("timestamp", timestamp);
requestMap.put("channelId", channelId);
requestMap.put("sign", LiveSignUtil.getSign(requestMap, appSecret));
String response = HttpUtil.get(url, requestMap);
log.info("测试查询频道实时推流信息,返回值:{}", response);
//do somethings
}
响应示例
系统全局错误说明详见全局错误说明
成功示例
{
"code": 200,
"status": "success",
"message": "",
"data": {
"deployAddress": null,
"inAddress": null,
"streamName": "1b448be32316919995083869e11",
"fps": "15.15",
"lfr": null,
"inBandWidth": "70058.266"
}
}
异常示例
{
"code": 400,
"status": "error",
"message": "invalid signature.",
"data": ""
}
Last updated
Was this helpful?