随笔 - 936  文章 - 0  评论 - 3  阅读 - 30万

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)
}
posted on   EasyGBS  阅读(32)  评论(0编辑  收藏  举报
编辑推荐:
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
阅读排行:
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构
· 提示词工程——AI应用必不可少的技术
· 字符编码:从基础到乱码解决
· 地球OL攻略 —— 某应届生求职总结
< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

点击右上角即可分享
微信分享提示