基于 SpringBoot+Hikvision SDK 远程查看配置海康网络摄像头配置

2023-10-22 18:50:10 浏览数 (2)

1写在前面

  • 工作中遇到,简单整理
  • 理解不足小伙伴帮忙指正

对每个人而言,真正的职责只有一个:找到自我。然后在心中坚守其一生,全心全意,永不停息。所有其它的路都是不完整的,是人的逃避方式,是对大众理想的懦弱回归,是随波逐流,是对内心的恐惧 ——赫尔曼·黑塞《德米安》


2海康设备 通过 SDK 查看修改网络摄像头配置

有个简单需求,需要通过程序远程修改 海康网络摄像头配置,可以在指定的时间间隔的情况下抓图,通过 FTP 传到指定服务器,需要修改的网络摄像头配置项:

  • FTP 配置 NET_DVR_SET_FTPCFG_V40,NET_DVR_GET_FTPCFG_V40
  • 抓图配置 NET_DVR_GET_JPEG_CAPTURE_CFG,NET_DVR_SET_JPEG_CAPTURE_CFG(图片大小等,时间间隔)
  • 抓图计划配置 NET_DVR_GET_SCHED_CAPTURECFG,NET_DVR_SET_SCHED_CAPTURECFG(每天什么时候抓图)

项目目录

代码语言:javascript复制
X:.
├─main
│  ├─java
│  │  └─com
│  │      └─xtj
│  │          └─hikvisionsdkintegration
│  │              ├─config
│  │              ├─controller
│  │              ├─dto
│  │              ├─sdklib
│  │              ├─service
│  │              ├─task
│  │              └─util
│  └─resources

项目地址:https://github.com/LIRUILONGS/Hikvision-sdk-Integration

调用方式通过接口调用,支持 Get,Post 方式

get 方式

代码语言:javascript复制
http://127.0.0.1:8099/config/state/192.168.1.143
http://127.0.0.1:8099/config/ftp?ips=192.168.1.143,192.168.1.141,192.168.1.142
http://127.0.0.1:8099/config/ftp/status?ips=192.168.1.143,192.168.1.141,192.168.1.142

post 方式

代码语言:javascript复制
curl --location --request POST 'http://127.0.0.1:8099/config/ftp' 
--header 'Content-Type: application/json' 
--data-raw ' [
    "192.168.1.143",
    "192.168.1.141",
    "192.168.1.142"
]'
代码语言:javascript复制
curl --location --request POST 'http://127.0.0.1:8099/config/ftp/status' 
--header 'Content-Type: application/json' 
--data-raw ' [
    "192.168.1.143",
    "192.168.1.141",
    "192.168.1.142"
]

'

提供了 swagger UI ,接口文档,可以直接调用

配置说明

代码语言:javascript复制
server:
  port: 8099
logging:
  level:
    org:
      springframework.web: info
# 摄像头配置
CAMERA:
  username: "admin"
  password: "hik12345"
# ftp 配置
FTP:
  username: "face"
  password: "face"
  serverIP: "110.110.110.110"
  serverPort: 21
  enableAnony: 0
  custdir: "face"
#抓图配置
snapshot:
  dwPicInterval: 4000 # 抓图时间间隔 4s

部署

当前 SDK , window 下需要把SDK 包和 当前项目 jar 包放到同一级目录, Linux 需放到 /usr/lib/ 下面

代码语言:javascript复制
java -jar  hikvision-sdk-integration-0.0.1-SNAPSHOT.jar

Docker 方式

代码语言:javascript复制
┌──[root@vms81.liruilongs.github.io]-[~/ftpconfig]
└─$ ls
Dockerfile  hikvision-sdk-integration-0.0.1-SNAPSHOT.jar  sdk  sdk.tar
┌──[root@vms81.liruilongs.github.io]-[~/ftpconfig]
└─$ cat Dockerfile

FROM openjdk:8u102-jdk

COPY ./hikvision-sdk-integration-0.0.1-SNAPSHOT.jar /
ADD  ./sdk.tar  /usr/lib/

# 设置容器启动时的命令
CMD ["java", "-jar" ,"hikvision-sdk-integration-0.0.1-SNAPSHOT.jar"]
┌──[root@vms81.liruilongs.github.io]-[~/ftpconfig]
└─$

仓库地址:https://hub.docker.com/r/liruilong/hikvision-sdk-config-ftp

代码语言:javascript复制
docker pull liruilong/hikvision-sdk-config-ftp
代码语言:javascript复制
┌──[root@vms81.liruilongs.github.io]-[~/ftpconfig]
└─$ docker run --rm -it -p 8099:8099 hikvision-sdk-config-ftp:latest

  .   ____          _            __ _ _
 /\ / ___'_ __ _ _(_)_ __  __ _    
( ( )___ | '_ | '_| | '_ / _` |    
 \/  ___)| |_)| | | | | || (_| |  ) ) ) )
  '  |____| .__|_| |_|_| |___, | / / / /
 =========|_|==============|___/=/_/_/_/
 :: Spring Boot ::                (v2.5.3)

2023-10-12 17:20:41.184  INFO 1 --- [           main] c.x.h.HikvisionSdkIntegrationApplication : Starting HikvisionSdkIntegrationApplication v0.0.1-SNAPSHOT using Java 1.8.0_102 on bbb649e2e354 with PID 1 (/hikvision-sdk-integration-0.0.1-SNAPSHOT.jar started by root in /)
2023-10-12 17:20:41.186  INFO 1 --- [           main] c.x.h.HikvisionSdkIntegrationApplication : No active profile set, falling back to default profiles: default
2023-10-12 17:20:42.650  INFO 1 --- [           main] o.s.b.w.embedded.tomcat.TomcatWebServer  : Tomcat initialized with port(s): 8099 (http)
2023-10-12 17:20:42.669  INFO 1 --- [           main] o.apache.catalina.core.StandardService   : Starting service [Tomcat]
2023-10-12 17:20:42.669  INFO 1 --- [           main] org.apache.catalina.core.StandardEngine  : Starting Servlet engine: [Apache Tomcat/9.0.50]
2023-10-12 17:20:42.764  INFO 1 --- [           main] o.a.c.c.C.[Tomcat].[localhost].[/]       : Initializing Spring embedded WebApplicationContext
.............
loop[2] find 2 mac and 0 ip
2023-10-12 17:20:44.151  INFO 1 --- [pool-1-thread-1] c.x.h.task.InitSdkTask                   : ============== InitSDK init success ====================
2023-10-12 17:21:02.986  INFO 1 --- [nio-8099-exec-1] o.a.c.c.C.[Tomcat].[localhost].[/]       : Initializing Spring DispatcherServlet 'dispatcherServlet'
2023-10-12 17:21:02.986  INFO 1 --- [nio-8099-exec-1] o.s.web.servlet.DispatcherServlet        : Initializing Servlet 'dispatcherServlet'
2023-10-12 17:21:02.988  INFO 1 --- [nio-8099-exec-1] o.s.web.servlet.DispatcherServlet        : Completed initialization in 2 ms
2023-10-12 17:21:03.243  INFO 1 --- [nio-8099-exec-1] c.x.h.controller.ConfigController        : userId=0
2023-10-12 17:21:03.286  INFO 1 --- [nio-8099-exec-1] c.x.h.controller.ConfigController        : 获取参数成功
2023-10-12 17:21:03.287  INFO 1 --- [nio-8099-exec-1] c.x.h.controller.ConfigController        : ===========================  设备信息  ============================
2023-10-12 17:21:03.287  INFO 1 --- [nio-8099-exec-1] c.x.h.controller.ConfigController        : 设备名称:IP CAMERA 设备序列号:DS-IPC-B12HV2-IA20210812AACHG51171281
2023-10-12 17:21:03.287  INFO 1 --- [nio-8099-exec-1] c.x.h.controller.ConfigController        : 设备型号名称:DS-IPC-B12HV2-IA 设备 型号:31
2023-10-12 17:21:03.287  INFO 1 --- [nio-8099-exec-1] c.x.h.controller.ConfigController        : 模拟通道个数:1
2023-10-12 17:21:03.289  INFO 1 --- [nio-8099-exec-1] c.x.h.controller.ConfigController        : 软件版本号:[firstVersion:5, secondVersion:5, lowVersion:34]
2023-10-12 17:21:03.289  INFO 1 --- [nio-8099-exec-1] c.x.h.controller.ConfigController        : 软件生成日期:Build:2021.7.14

海康 SDK 使用

开发手册,动态库下载:

https://open.hikvision.com/download/5cda567cf47ae80dd41a54b3?type=10&id=5cda5902f47ae80dd41a54b7

  • 确定需要调用的动态库功能
  • 通过开发手册查看对应的宏定义,结构体
  • 定义宏变量,结构体转化
  • 编写需要的功能业务,可以参考官方的 Demo

以 FTP 配置为 Demo:

宏变量

代码语言:javascript复制
    public static final int NET_DVR_GET_FTPCFG_V40 = 6162;  //获取FTP信息
    public static final int NET_DVR_SET_FTPCFG_V40 = 6163;  //设置FTP信息

结构体转化

代码语言:javascript复制

    public static class NET_DVR_STRUCTHEAD extends Structure {
        public short wLength;        //结构长度
        public byte byVersion ;    /*高低4位分别代表高低版本,后续根据版本和长度进行扩展,不同的版本的长度进行限制*/
        public byte byRes;
    }

    //图片命名扩展 2013-09-27
    public static class NET_DVR_PICTURE_NAME_EX extends Structure {
        public byte[] byItemOrder = new byte[PICNAME_MAXITEM];    /*    桉数组定义文件命名的规则 */
        public byte byDelimiter;                    /*分隔符,一般为'_'*/
        public byte[] byPicNamePrefix = new byte[PICNAME_PREFIX/*32*/];  //图片名自定义前缀
    }

    public static class STRUCT_SELF_DOMAIN extends Structure {
        public byte[] szDomain = new byte[64];        //服务器地址,可以使IPv4 IPv6或是域名
        public byte[] byRes1 = new byte[80];
    }

    public static class STRUCT_SELF_IP extends Structure {
        public NET_DVR_IPADDR struIp = new NET_DVR_IPADDR(); /*IP地址:IPv4 IPv6地址, 144字节*/
    }


    public static class UNION_SELF_FTPSEVER extends Union {
        public STRUCT_SELF_DOMAIN struDomain = new STRUCT_SELF_DOMAIN();
        public STRUCT_SELF_IP struAddrIP = new STRUCT_SELF_IP();
    }

    public static class NET_DVR_FTPCFG_V40 extends Structure {
        public NET_DVR_STRUCTHEAD struStruceHead = new NET_DVR_STRUCTHEAD();
        public byte byEnableFTP;            /*是否启动ftp上传功能,0-否,1-是*/
        public byte byProtocolType;             /*协议类型 0-FTP,1-SFTP*/
        public short wFTPPort;                /*端口*/
        public UNION_SELF_FTPSEVER unionServer = new UNION_SELF_FTPSEVER();
        public byte[] szUserName = new byte[32];            /*用户名*/
        public byte[] szPassWORD = new byte[16];            /*密码*/
        public byte[] szTopCustomDir = new byte[64];        /*自定义一级目录*/
        public byte[] szSubCustomDir = new byte[64];        /*自定义二级目录*/
        public byte byDirLevel;                /*0 = 不使用目录结构,直接保存在根目录,    1 = 使用1级目录,2=使用2级目录*/
        public byte byTopDirMode;            /* 一级目录,0x1 = 使用设备名,0x2 = 使用设备号,0x3 = 使用设备ip地址,
                                                    0x4=使用监测点,0x5=使用时间(年月),0x6-使用自定义 ,0x7=违规类型,0x8=方向,0x9=地点*/
        public byte bySubDirMode;           /*二级目录,0x1=使用通道名,0x2=使用通道号 0x3=使用时间(年月日),
                                                    0x4=使用车道号,0x5-使用自定义, 0x6=违规类型,0x7=方向,0x8=地点,0x9 = 车位编号*/
        public byte byType;                    /* 0-主服务器,1-备服务器*/
        public byte byEnableAnony;          /*启用匿名 0-否 1是*/
        public byte byAddresType;           /*0 使用IPV4、IPV6  1- 使用域名*/
        public byte byFTPPicType;           //0-保留,1-停车场抓拍图片命名规则
        public byte byPicArchivingInterval; //图片归档间隔[1~30],0表示关闭
        public NET_DVR_PICTURE_NAME_EX struPicNameRule = new NET_DVR_PICTURE_NAME_EX();   /* 图片命名规则:
        byFTPPicType ==1的时候,自数组内的命名规则是停车场抓拍图片命名规则*/
        public byte byPicNameRuleType;      //图片命令规则类型;0~默认类型,1~图片前缀名定义(启用struPicNameRule中的byPicNamePrefix字段)
        public byte[] byRes = new byte[203];             /*保留*/


    }

    public static class NET_DVR_FTP_TYPE extends Structure {
        public byte byType;  // 0-主服务器,1-备服务器
        public byte[] byRes = new byte[3];
    }

编写功能业务

3博文部分内容参考

© 文中涉及参考链接内容版权归原作者所有,如有侵权请告知,这是一个开源项目,如果你认可它,不要吝啬星星哦 :)

https://github.com/LIRUILONGS/Hikvision-sdk-Integration

https://open.hikvision.com/download/5cda567cf47ae80dd41a54b3?type=10&id=5cda5902f47ae80dd41a54b7

https://gitee.com/naylor_personal/ramble-spring-boot/tree/master/hikvision-sdk-integration

© 2018-2023 liruilonger@gmail.com, All rights reserved. 保持署名-非商用-相同方式共享(CC BY-NC-SA 4.0)

0 人点赞