EasyGBS批量接入设备导出通道的实现过程分享

2021-10-08 15:37:19 浏览数 (1)

TSINGSEE青犀视频开发的国标GB28181协议视频智能分析平台EasyGBS已经兼容了采集-存储-展示-告警这四大模块的内容处理,能够为大数据平台的搭建提供视频能力上的支持。目前EasyGBS正在积极进行内核的改版,力求做到更加稳定、更加高质量。

上一篇博文我们分享了设备通道一键导入的功能实现,本文我们再分享一下一键导出功能。

首先在设备后端服务器保存一个固定的通道导出信息模板

设备信息导出模板:

通道信息导出模板:

再将所有的通道配置信息,由数据库按照不同的类型读出并写入到指定的模板中,并下载到用户浏览器端。

部分代码展示:

代码语言:javascript复制
func (h *APIHandler) ExportChannel(c *gin.Context) {
   option := c.Param("option")
   dbPath := utils.DBFile()
   if !utils.Exist(dbPath) {
      c.AbortWithStatusJSON(500, "配置数据未找到")
      return
   }
   demo := filepath.Join(utils.DataDir(), "ChannelInfo.xlsx")
   if !utils.Exist(demo) {
      c.AbortWithStatusJSON(500, "模板文件未找到")
      return
   }
   xlsxFile, err := createExportInfoXlsx(demo, option)
   if err != nil {
      c.AbortWithStatusJSON(http.StatusInternalServerError, err.Error())
      os.RemoveAll(xlsxFile)
      return
   }
   defer os.RemoveAll(xlsxFile)
 
   filename := fmt.Sprintf("EasyGBS%sChannels.xlsx", option)
   header := c.Writer.Header()
   header["Content-type"] = []string{"application/octet-stream"}
   header["Content-Disposition"] = []string{"attachment; filename="   filename}
   c.File(xlsxFile)
}

0 人点赞