首页 > 新闻中心 > 掌酷科技 > 数码 > VRAR >

EasyNVR平台实现播流地址超时无法播放功能过程分
2021-06-04 10:29 EasyNVR

EasyNVR平台中会生成 hls、flv、ws-flv 等多种流,当用户获取对应的流地址后,可以一直播放,因此需要对流地址进行超时管理,如果超时后无法播放。

设计方案如下:

1、首先在生成的播流地址中添加 expire参数,即播流地址为:

http://127.0.0.1:10800/flv/hls/stream_1.flv?expire=eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJleHAiOjE2MjIxMTIxNTAsImlzcyI6InRzaW5nc2VlLWVhc3ludnIifQ.DlKQtcQZuYi0NcL_bWZWrWU1KDAMGueb8jwBxK_vqzc ;

2、如果播流地址中不包含 expire 参数,则返回无权限播放;

3、如果播流地中包含 expire 参数,解析参数过期时间,如果超时,则返回无权限播放。

expire 的生成代码如下:

func GeneratePlayToken(expireTime time.Time) (string, error) {
//设置token有效时间
/*nowTime:=time.Now()
expireTime:=nowTime.Add(3*time.Hour)*/
claims := jwt.StandardClaims{
// 过期时间
ExpiresAt: expireTime.Unix(),
// 指定token发行人
Issuer: "tsingsee-easynvr",
}
tokenClaims := jwt.NewWithClaims(jwt.SigningMethodHS256, claims)
//该方法内部生成签名字符串,再用于获取完整、已签名的token
token, err := tokenClaims.SignedString(jwtSecret)
return token, err
}

解析 expire 的代码如下:

// 返回 token 是否有效
func ParsePlayToken(token string) (bool, int, error) {
//用于解析鉴权的声明,方法内部主要是具体的解码和校验的过程,最终返回*Token
tokenClaims, err := jwt.ParseWithClaims(token, &jwt.StandardClaims{}, func(token *jwt.Token) (interface{}, error) {
return jwtSecret, nil
})
if tokenClaims != nil {
// 从tokenClaims中获取到Claims对象,并使用断言,将该对象转换为我们自己定义的Claims
// 要传入指针,项目中结构体都是用指针传递,节省空间。
if claims, ok := tokenClaims.Claims.(*jwt.StandardClaims); ok && tokenClaims.Valid {
dura := int(claims.ExpiresAt - time.Now().Unix())
if dura > 0 {
return true, dura, nil
} else {
return false, 0, nil
}
}
标签: 超时 地址 过程 无法播放
0

上一篇:EasyCVR视频平台接入海康私有协议设备的常见问题
下一篇:没有了
官方微信公众号:掌酷门户(wapzknet)

首页 > 新闻中心 > 掌酷科技 > 数码 > VRAR >
相关资讯

新闻热点
精选美图


客户端合作免责友链
Copyright 2009-2021 蜀ICP备09035849号