视频综合管理平台EasyNVS定制版本如何添加“根据创建时间搜索”的功能?

2021-02-22 14:33:57 浏览数 (2)

TSINGSEE青犀视频开发的视频平台是支持定制的,比如EasyDSS、EasyNVR等平台我们都为多个客户开发过定制版本,有定制需求的用户可以联系我们。

EasyNVS作为TSINGSEE青犀视频开发的视频综合管理平台,也是支持定制的,我们在某个项目中定制EasyNVS时,就需要添加一个根据创建时间搜索的功能,本文我们就和大家分享下我们的实现过程。

根据创建时间来搜索,我们只需在后端添加一个搜索功能即可,参考以下代码,通过数据库对创建时间进行筛选。

代码语言:javascript复制
func (h *APIHandler) GetAllDevice(c *gin.Context) {
   var err error
   defer func() {
      if p := recover(); p != nil {
         err = fmt.Errorf("%v", p)
      }
      if err != nil {
         c.AbortWithStatusJSON(400, err.Error())
         return
      }
   }()
   pageForm := utils.NewPageForm()
   err = c.Bind(pageForm)
   if err != nil {
      return
   }
   q := db.SQLite.Model(models.Device{})
   devices := make([]*models.Device, 0)
 
   if pageForm.StartTime != "" && pageForm.EndTime != "" {
      pageForm.StartTime = fmt.Sprintf("%s 00:00:00", pageForm.StartTime)
      pageForm.EndTime = fmt.Sprintf("%s 23:59:59", pageForm.EndTime)
      q = q.Where("created_at BETWEEN ? AND ?", pageForm.StartTime, pageForm.EndTime)
   }
   if pageForm.Q != "" {
      q = q.Where("id like ? or name like ?", "%" pageForm.Q "%", "%" pageForm.Q "%").Find(&devices)
   }
   if pageForm.Sort != "" {
      q = q.Order(fmt.Sprintf("%s %s", gorm.ToDBName(pageForm.Sort), pageForm.Order))
   } else {
      q = q.Order("created_at desc")
   }
   total := 0
   q.Count(&total)
   q.Limit(pageForm.Limit).Offset(pageForm.Start).Find(&devices)
   c.IndentedJSON(200, gin.H{
      "DeviceCount": total,
      "DeviceList":  devices,
   })
}

实现之后的界面如下图:

EasyNVS云管理平台可以配合EasyNVR服务实现外网的无插件视频直播,可以做到云端分发、H5快速起播这类的视频功能和需求,当然也具备最基础的视频统一管理功能。如果大家想要了解更多关于EasyNVS的相关内容,欢迎联系我们了解或者试用!

0 人点赞