栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 前沿技术 > 大数据 > 其他

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

其他 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

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

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

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

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

设备信息导出模板:

通道信息导出模板:

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

部分代码展示:

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)
}
转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/279159.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号