API V1

最近更新时间: 2017-08-16 08:18:20

huxicong·发表于:2016-08-12 15:22·更新于:2016-11-21 18:14

创建流

请求 hub.createStream(title, publishKey, publishSecurity);

参数 说明
title (string) 流名,必须满足 namePattern, err := regexp.Compile("^[a-zA-Z0-9_-]{4,200}$格式
publishKey(string) 验证的key
publishSecurity 鉴权方式"dynamic" 或 "static" ,"dynamic" 为默认的
POST /v1/streams HTTP/1.1
Host: pili.qiniuapi.com
Accept: */*
Accept-Encoding: deflate, gzip
Content-Type: application/json
Authorization: Qiniu vI2xPIjOoh7udcRw4GdYNvf3o_gKsCx9wdZaC9u-:oJeCsKJUyv6KCLlnP4vyCheYKnk=
Content-Length: 87

{"hub":"1314xicong","title":"hello","publishKey":"huxicong","publishSecurity":"static"}

响应

{
    "id": "z1.1314xicong.hello",
    "createdAt": "2016-08-08T11:50:22.09+08:00",
    "updatedAt": "2016-08-08T11:50:22.09+08:00",
    "title": "hello",
    "hub": "1314xicong",
    "disabledTill": 0,
    "disabled": false,
    "publishKey": "huxicong",
    "publishSecurity": "static",
    "hosts": {
        "publish": {
            "rtmp": "pili-publish.pili.echohu.top"
        },
        "live": {
            "hdl": "pili-live-hdl.pili.echohu.top",
            "hls": "pili-live-hls.pili.echohu.top",
            "http": "pili-live-hls.pili.echohu.top",
            "rtmp": "pili-live-rtmp.pili.echohu.top",
            "snapshot": "100008j.live1-snapshot.z1.pili.qiniucdn.com"
        },
        "playback": {
            "hls": "100008j.playback1.z1.pili.qiniucdn.com",
            "http": "100008j.playback1.z1.pili.qiniucdn.com"
        },
        "play": {
            "http": "pili-live-hls.pili.echohu.top",
            "rtmp": "pili-live-rtmp.pili.echohu.top"
        }
    }
}

获取流

请求

hub.getStream(streamId)

streamId(这是流的标示 z1.1314xicong.huxicongp )

GET /v1/streams/z1.1314xicong.hello HTTP/1.1
Host: pili.qiniuapi.com
Accept: */*
Accept-Encoding: deflate, gzip
Content-Type: application/json
User-Agent: pili-sdk-php/1.5.4 curl/7.47.1 PHP/7.0.8
Authorization: Qiniu vI2xPIjOoh7udcRw4GdYNvf3o_gKsCx9wdZaC9u-:yvLyCKiXvBdAWgGGDyLIZUvMCmY=

响应

{
    "id": "z1.1314xicong.hello",
    "createdAt": "2016-08-08T11:50:22.09+08:00",
    "updatedAt": "2016-08-08T11:50:22.09+08:00",
    "title": "hello",
    "hub": "1314xicong",
    "disabledTill": 0,
    "disabled": false,
    "publishKey": "huxicong",
    "publishSecurity": "static",
    "hosts": {
        "publish": {
            "rtmp": "pili-publish.pili.echohu.top"
        },
        "live": {
            "hdl": "pili-live-hdl.pili.echohu.top",
            "hls": "pili-live-hls.pili.echohu.top",
            "http": "pili-live-hls.pili.echohu.top",
            "rtmp": "pili-live-rtmp.pili.echohu.top",
            "snapshot": "100008j.live1-snapshot.z1.pili.qiniucdn.com"
        },
        "playback": {
            "hls": "100008j.playback1.z1.pili.qiniucdn.com",
            "http": "100008j.playback1.z1.pili.qiniucdn.com"
        },
        "play": {
            "http": "pili-live-hls.pili.echohu.top",
            "rtmp": "pili-live-rtmp.pili.echohu.top"
        }
    }
}

列举流

请求

hub.listStreams(marker, limit, title_prefix, status);

参数 说明
title_prefix (string)字符串,可选,限定只返回带以 prefix 为前缀的流名,不指定表示不限定前缀。
limit (int)整数,可选,限定返回的流个数,不指定表示遵从系统限定的最大个数。
marker (int)字符串,可选,上一次查询返回的标记,用于提示服务端从上一次查到的位置继续查询,不指定表示从头查询。
GET /v1/streams?hub=1314xicong&limit=2 HTTP/1.1
Host: pili.qiniuapi.com
Accept: */*
Accept-Encoding: deflate, gzip
Content-Type: application/json
User-Agent: pili-sdk-php/1.5.4 curl/7.47.1 PHP/7.0.8
Authorization: Qiniu vI2xPIjOoh7udcRw4GdYNvf3o_gKsCx9wdZaC9u-:mTUdSB0pTLQka-rpfNf4jM36l28=

响应

{
    "marker": "2",
    "items": [
        {
            "id": "z1.1314xicong.hello",
            "createdAt": "2016-08-08T11:50:22.09+08:00",
            "updatedAt": "2016-08-08T11:50:22.09+08:00",
            "title": "hello",
            "hub": "1314xicong",
            "disabledTill": 0,
            "disabled": false,
            "publishKey": "huxicong",
            "publishSecurity": "static",
            "hosts": {
                "publish": {
                    "rtmp": "pili-publish.pili.echohu.top"
                },
                "live": {
                    "hdl": "pili-live-hdl.pili.echohu.top",
                    "hls": "pili-live-hls.pili.echohu.top",
                    "http": "pili-live-hls.pili.echohu.top",
                    "rtmp": "pili-live-rtmp.pili.echohu.top",
                    "snapshot": "100008j.live1-snapshot.z1.pili.qiniucdn.com"
                },
                "playback": {
                    "hls": "100008j.playback1.z1.pili.qiniucdn.com",
                    "http": "100008j.playback1.z1.pili.qiniucdn.com"
                },
                "play": {
                    "http": "pili-live-hls.pili.echohu.top",
                    "rtmp": "pili-live-rtmp.pili.echohu.top"
                }
            }
        },
        {
            "id": "z1.1314xicong.57a801305e77b03d5202aa31",
            "createdAt": "2016-08-08T11:49:04.224+08:00",
            "updatedAt": "2016-08-08T11:49:04.224+08:00",
            "title": "57a801305e77b03d5202aa31",
            "hub": "1314xicong",
            "disabledTill": 0,
            "disabled": false,
            "publishKey": "b321c6c6-9004-4cad-b29a-7d5dec42659b",
            "publishSecurity": "static",
            "hosts": {
                "publish": {
                    "rtmp": "pili-publish.pili.echohu.top"
                },
                "live": {
                    "hdl": "pili-live-hdl.pili.echohu.top",
                    "hls": "pili-live-hls.pili.echohu.top",
                    "http": "pili-live-hls.pili.echohu.top",
                    "rtmp": "pili
123.059.063.003.00080-192.168.200.120.61037: -live-rtmp.pili.echohu.top",
                    "snapshot": "100008j.live1-snapshot.z1.pili.qiniucdn.com"
                },
                "playback": {
                    "hls": "100008j.playback1.z1.pili.qiniucdn.com",
                    "http": "100008j.playback1.z1.pili.qiniucdn.com"
                },
                "play": {
                    "http": "pili-live-hls.pili.echohu.top",
                    "rtmp": "pili-live-rtmp.pili.echohu.top"
                }
            }
        }
    ],
    "end": false
}

流的更新

stream.updata()

POST /v1/streams/z1.1314xicong.hello HTTP/1.1
Host: pili.qiniuapi.com
Accept: */*
Accept-Encoding: deflate, gzip
Content-Type: application/json
User-Agent: pili-sdk-php/1.5.4 curl/7.47.1 PHP/7.0.8
Authorization: Qiniu vI2xPIjOoh7udcRw4GdYNvf3o_gKsCx9wdZaC9u-:d9Ak7nhlZoc3AAudOGHd6QxRB7Q=
Content-Length: 60

{"publishKey":"new_secret_words","publishSecurity":"static"}

响应

{
    "id": "z1.1314xicong.hello",
    "createdAt": "2016-08-08T11:50:22.09+08:00",
    "updatedAt": "2016-08-08T13:00:10.281105075+08:00",
    "title": "hello",
    "hub": "1314xicong",
    "disabledTill": 0,
    "disabled": false,
    "publishKey": "new_secret_words",
    "publishSecurity": "static",
    "hosts": {
        "publish": {
            "rtmp": "pili-publish.pili.echohu.top"
        },
        "live": {
            "hdl": "pili-live-hdl.pili.echohu.top",
            "hls": "pili-live-hls.pili.echohu.top",
            "http": "pili-live-hls.pili.echohu.top",
            "rtmp": "pili-live-rtmp.pili.echohu.top",
            "snapshot": "100008j.live1-snapshot.z1.pili.qiniucdn.com"
        },
        "playback": {
            "hls": "100008j.playback1.z1.pili.qiniucdn.com",
            "http": "100008j.playback1.zone1.pili.qiniucdn.com"
        },
        "play": {
            "http": "pili-live-hls.pili.echohu.top",
            "rtmp": "pili-live-rtmp.pili.echohu.top"
        }
    }
}

流的禁止与启用

流的禁止

disabledTill:(时间戳)在什么时间把它给禁止掉

stream.disable(disabledTill);

POST /v1/streams/z1.1314xicong.huxicongp/available HTTP/1.1
Host: pili.qiniuapi.com
Accept: */*
Accept-Encoding: deflate, gzip
Content-Type: application/json
User-Agent: pili-sdk-php/1.5.4 curl/7.47.1 PHP/7.0.8
Authorization: Qiniu vI2xPIjOoh7udcRw4GdYNvf3o_gKsCx9wdZaC9u-:m5mdD-RngQE9SwruF6Qc93qCSyw=

{"available":"disabled","disabledTill":1470633009}
HTTP/1.1 204 No Content

流的启用

stream.enable()

POST /v1/streams/z1.1314xicong.huxicongp/available HTTP/1.1
Host: pili.qiniuapi.com
Accept: */*
Accept-Encoding: deflate, gzip
Content-Type: application/json
User-Agent: pili-sdk-php/1.5.4 curl/7.47.1 PHP/7.0.8
Authorization: Qiniu vI2xPIjOoh7udcRw4GdYNvf3o_gKsCx9wdZaC9u-:PNk9q1aCLiWk_MqpZWTk5l_2Rr0=
Content-Length: 23

{"available":"enabled"}

 HTTP/1.1 204 No Content

这两个请求以状态码来判断是否请求成功 200

流的状态获取

stream.status()

流的状态包括(connect 连接 和disconnect 未连接)

GET /v1/streams/z1.1314xicong.huxicongp/status HTTP/1.1
Host: pili.qiniuapi.com
Accept: */*
Accept-Encoding: deflate, gzip
Content-Type: application/json
User-Agent: pili-sdk-php/1.5.4 curl/7.47.1 PHP/7.0.8
Authorization: Qiniu vI2xPIjOoh7udcRw4GdYNvf3o_gKsCx9wdZaC9u-:sZvsYZ4t_3zt_m6pNrZZEONW7po=

响应

HTTP/1.1 200 OK
{
    "reqId": "",
    "hub": "1314xicong",
    "stream": "huxicongp",
    "startFrom": "0001-01-01T00:00:00Z",
    "updatedAt": "0001-01-01T00:00:00Z",
    "addr": "",
    "status": "disconnected",
    "bytesPerSecond": 0,
    "framesPerSecond": {
        "audio": 0,
        "video": 0,
        "data": 0
    }
}

获取播放URL(flv RTMP hls) 推流URL

urls = stream.httpFlvLiveUrls();//获取flv的播放地址

urls = stream.hlsLiveUrls();//获取hls的播放地址

urls = stream.rtmpLiveUrls();//获取RTMP的播放地址

publishUrl = stream.rtmpPublishUrl();//获取推流地址

GET /v1/streams/z1.1314xicong.huxicongp HTTP/1.1
Host: pili.qiniuapi.com
Accept: */*
Accept-Encoding: deflate, gzip
Content-Type: application/json
User-Agent: pili-sdk-php/1.5.4 curl/7.47.1 PHP/7.0.8
Authorization: Qiniu vI2xPIjOoh7udcRw4GdYNvf3o_gKsCx9wdZaC9u-:Knw_76FTr_FSz5-VHM5Xj4ERmhs=

HTTP/1.1 200 OK

响应

{
    "id": "z1.1314xicong.huxicongp",
    "createdAt": "2016-07-12T18:06:29.009+08:00",
    "updatedAt": "2016-07-12T18:06:29.009+08:00",
    "title": "huxicongp",
    "hub": "1314xicong",
    "disabledTill": 0,
    "disabled": false,
    "publishKey": "b321c6c6-9004-4cad-b29a-7d5dec42659b",
    "publishSecurity": "static",
    "hosts": {
        "publish": {
            "rtmp": "pili-publish.pili.echohu.top"
        },
        "live": {
            "hdl": "pili-live-hdl.pili.echohu.top",
            "hls": "pili-live-hls.pili.echohu.top",
            "http": "pili-live-hls.pili.echohu.top",
            "rtmp": "pili-live-rtmp.pili.echohu.top",
            "snapshot": "100008j.live1-snapshot.z1.pili.qiniucdn.com"
        },
        "playback": {
            "hls": "100008j.playback1.z1.pili.qiniucdn.com",
            "http": "100008j.playback1.z1.pili.qiniucdn.com"
        },
        "play": {
            "http": "pili-live-hls.pili.echohu.top",
            "rtmp": "pili-live-rtmp.pili.echohu.top"
        }
    }
}
返回信息

string(97) "rtmp://pili-publish.pili.echohu.top/1314xicong/huxicongp?key=b321c6c6-9004-4cad-b29a-7d5dec42659b"
array(1) {
  ["ORIGIN"]=>
  string(58) "rtmp://pili-live-rtmp.pili.echohu.top/1314xicong/huxicongp"
}
array(1) {
  ["ORIGIN"]=>
  string(61) "http://pili-live-hdl.pili.echohu.top/1314xicong/huxicongp.flv"
}
array(1) {
  ["ORIGIN"]=>
  string(62) "http://pili-live-hls.pili.echohu.top/1314xicong/huxicongp.m3u8"
}

获取推流历史记录 并 保存( 得有历史推流数据才可以获取得到 才能保存回放)

获取流的历史推流记录

stream.segments(start, end, limit);

参数 说明
start (时间戳)获取的开始时间段
end (时间戳)获取的结束时间段
limit (int)限制最多得到的信息数
GET /v1/streams/z1.1314xicong.mytest/segments HTTP/1.1
Host: pili.qiniuapi.com
Accept: */*
Accept-Encoding: deflate, gzip
Content-Type: application/json
User-Agent: pili-sdk-php/1.5.4 curl/7.47.1 PHP/7.0.8
Authorization: Qiniu vI2xPIjOoh7udcRw4GdYNvf3o_gKsCx9wdZaC9u-:2eEI-1NL_xAVjuon-wfZ72pgiEc=

HTTP/1.1 200 OK

{"start":1462417984,"end":1462417993,"duration":9,"segments":[{"start":1462417984,"end":1462417993}]}

将流保存回放

stream.saveAs(name, format, start, end, notifyUrl, pipeline);

参数 说明
name (string) 保存的文件名
format 保存的文件格式 null为m3u8 ( optional)
start & end (时间戳或-1)指定保存的时间段 传 -1 这个时间段是上面的历史推流记录{"start":1462417984,"end":1462417993}
notifyUrl (string ) 合并成MP4文件时处理成功通过这个回调通知你的服务器url
pipeline 处理的队列 保存为mp4需要指定下队列 不然处理速度很慢
192.168.200.120.61423-123.059.063.003.00080: POST /v1/streams/z1.1314xicong.huxicongp/saveas HTTP/1.1
Host: pili.qiniuapi.com
Accept: */*
Accept-Encoding: deflate, gzip
Content-Type: application/json
User-Agent: pili-sdk-php/1.5.4 curl/7.47.1 PHP/7.0.8
Authorization: Qiniu vI2xPIjOoh7udcRw4GdYNvf3o_gKsCx9wdZaC9u-:mCB1hBdmSE8amWIO9Ww_pRX7dqc=

{"name":"videoName.mp4","start":-1,"end":-1}
HTTP/1.1 200 OK

响应

{
"url":"http://pili-media.pili.echohu.top/recordings/z1.1314xicong.huxicongp/videoName.m3u8","duration":2569,
"persistentId":""
}

流的删除

stream.delete()

DELETE /v1/streams/z1.1314xicong.huxicongp HTTP/1.1
Host: pili.qiniuapi.com
Accept: */*
Accept-Encoding: deflate, gzip
Content-Type: application/json
User-Agent: pili-sdk-php/1.5.4 curl/7.47.1 PHP/7.0.8
Authorization: Qiniu vI2xPIjOoh7udcRw4GdYNvf3o_gKsCx9wdZaC9u-:iGQX6GfyDaiU6CetyCOhLZOdkmY=

HTTP/1.1 204 No Content

直播截图(使用时必须在有直播的状态下才可以使用)

stream.snapshot(name, format, time, notifyUrl, pipeline)

参数 说明
name 保存的文件名
format 保存的文件的格式 填 'jpg','png'
time 截取的时间
notifyUrl 截图成功通知回调的URL
pipeline 队列
POST /v1/streams/z1.1314xicong.huxicongp/snapshot HTTP/1.1
Host: pili.qiniuapi.com
Accept: */*
Accept-Encoding: deflate, gzip
Content-Type: application/json
User-Agent: pili-sdk-php/1.5.4 curl/7.47.1 PHP/7.0.8
Authorization: Qiniu vI2xPIjOoh7udcRw4GdYNvf3o_gKsCx9wdZaC9u-:I8-k7BbBiqwdLyvIqimFUhpNmDM=
Content-Length: 57

{"name":"imageName.jpg","format":"jpg","time":1470641287}
HTTP/1.1 200 OK

相应

{"targetUrl":"http://pili-static.pili.echohu.top/snapshots/z1.1314xicong.huxicongp/imageName.jpg"}

附录

手机端的json推流方式只支持(static 和 dynamic)

首先以上几种获取的流的json的方法都是支持调用的 (记得流必须是开启的 不是禁用的)

Stream = hub.createStream(title, publishKey, publishSecurity) //重新创建一路流来推

Stream = hub.getStream(streamId) //获取已经存在的流 来推流

Stream.toJSONString() 将这个返回给客户端

以上内容是否对您有帮助?
  • Qvm free helper
    Close