前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >EasyGBS批量接入设备导出通道的实现过程分享

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

原创
作者头像
TSINGSEE青犀视频
修改2021-10-08 15:37:19
3200
修改2021-10-08 15:37:19
举报
文章被收录于专栏:TSINGSEE青犀视频

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)
}

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
智能推荐平台
智能推荐平台(Intelligent Recommendation Platform,IRP)是集生态、技术、场景于一体,采用业界领先的AI学习技术和智能推荐算法,基于腾讯多年在超大型场景中积累的最佳实践方法论,助力客户业务实现增长的企业级应用产品。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档