EasyGBS批量接入设备及导入通道的实现过程分享
EasyGBS是TSINGSEE青犀视频研发的可接入国标GB28181协议的视频平台,经过多年的沉淀和不断的优化,EasyGBS目前已经适应了很多场景下的视频监控可视化搭建,并且能够提供丰富的二次接口进行开发。
为了方便EasyGBS的日常运维和现场部署,需要用户和运维人员能够通过简单的方式,批量的配置EasyGBS后台的接入通道配置。并且能够随时了解通道配置的具体情况,因此在前端提供一个通道信息的一键导入功能。
首先设定一个固定的通道导入信息模板:
设备信息导入模板:
通道信息导入模板。
后端保存文件通道信息内容,选择是更新或者新建通道和设备信息。
func (h *APIHandler) ImportChannelInfo(c *gin.Context) {
file, err := c.FormFile("file")
if err != nil {
err = fmt.Errorf("获取上传文件错误, %v", err)
c.AbortWithStatusJSON(http.StatusBadRequest, err.Error())
return
}
ext := filepath.Ext(file.Filename)
if ext != ".xlsx" {
err = fmt.Errorf("上传文件格式错误, %v", err)
c.AbortWithStatusJSON(http.StatusBadRequest, err.Error())
return
}
tmp := "tmp.xlsx"
f, err := os.Create(tmp)
if err != nil {
err = fmt.Errorf("新建文件失败, %v", err)
c.AbortWithStatusJSON(http.StatusInternalServerError, err.Error())
return
}
err = c.SaveUploadedFile(file, tmp)
if err != nil {
err = fmt.Errorf("保存上传文件错误, %v", err)
c.AbortWithStatusJSON(http.StatusInternalServerError, err.Error())
return
}
xlFile, e := xlsx.OpenFile(tmp)
if e != nil {
err = fmt.Errorf("xlsx open error, %v", e)
c.AbortWithStatusJSON(http.StatusInternalServerError, err.Error())
return
}
defer func() {
f.Close()
os.RemoveAll(tmp)
}()
err = importInfo(xlFile)
if err != nil {
c.AbortWithStatusJSON(http.StatusInternalServerError, err.Error())
return
}
c.AbortWithStatusJSON(http.StatusOK, "ok")
return
}
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构
· 提示词工程——AI应用必不可少的技术
· 字符编码:从基础到乱码解决
· 地球OL攻略 —— 某应届生求职总结