第一次部署海康威视DEMO的一些坑,最终运行成功

海康威视(HIKVISION) JAVA SDK Demo成功运行

引子

调海康的JAVA SDK花费时间较长,所以记录下,为其他小伙伴填填坑,提高一下效率。官方文档确实少,而且demo中的说明各种坑。

下载

官方SDK下载地址:https://www.hikvision.com/cn/download_more_570.html(64位SDK)

注意:官方SDK区分32位和64位,如果用64位的SDK需要使用JDK64位的,不能使用32位JDK。32位的SDK同理,只能使用32位JDK的

说明

官方的Demo的编译环境:Eclipse+Swing插件 或者 NetBeans IDE V8.2,使用的JDK为1.8。

我使用IDEA编译通过了,Eclipse和IDEA区别不大。我的编译环境:IDEA+JDK1.8(64位)+ Windows 10(64位)。编译环境全是在64位下进行的。

海康威视SDK版本:设备网络SDK_V6.0.2.35(for Windows x64)

代码编译

导入项目时选择eclipse项目导入,如果不懂的同学可以搜索下 IDEA如何导入ecplise项目,项目导进来后根据demo中的 SDK库文件拷贝到该目录下.txt 文件中的描述:

【注意事项】
------------------------------------
1. 请到海康威视官网下载最新版本设备网络SDK:http://www.hikvision.com/Cn/download_more_401.html
  1. 请修改程序代码,其中HCNetSDK.java文件自己指定loadlibrary加载库的路径,【库文件】里的HCNetSDK.dll、HCCore.dll、PlayCtrl.dll、SuperRender.dll、HCNetSDKCom文件夹等文件均拷贝到该路径下。 HCNetSDKCom文件夹(包含里面的功能组件dll库文件)需要和HCNetSDK.dll、HCCore.dll一起加载,放在同一个目录下,且HCNetSDKCom文件夹名不能修改。

  2. 如果自行开发软件不能正常实现相应功能,而且程序没有指定加载的dll库路径,请在程序运行的情况下尝试删除HCNetSDK.dll。如果可以删除,说明程序可能调用到系统盘Windows->System32目录下的dll文件,建议删除或者更新该目录下的相关dll文件;如果不能删除,dll文件右键选择属性确认SDK库版本。

  3. 如按上述步骤操作后还是不能实现相应功能,请根据NET_DVR_GetLastError返回的错误号判断原因。

添加文件

根据文件描述步骤拷入对应的文件和文件夹。第二条中少写了一个dll是 AudioRender.dll 请将此dll一并拷贝到项目的根目录下。

完成后,我们的项目目录是这个样子
项目目录列表
如果项目报错,将项目中的 jna.jar 包添加到项目的Libraries中。

项目不报错后,可以打开 ClientDemo.java 中的main方法运行一下。如果能成功运行,祝贺你,或许你已经可以调通设备了。如果不能运行请往下继续阅读。

问题

Exception in thread "main" java.lang.UnsatisfiedLinkError: Unable to load library 'HCNetSDK: ÕҲ»µ½ָ¶

Exception in thread “main” java.lang.UnsatisfiedLinkError: Unable to load library ‘PlayCtrl’: ÕҲ»µ½ָ¶¨

遇到上述的两种错误时,不要惊慌,打开 HCNetSDK.java 文件。

更改

HCNetSDK INSTANCE = (HCNetSDK) Native.loadLibrary("HCNetSDK", HCNetSDK.class);

 
 
  • 1

HCNetSDK INSTANCE = (HCNetSDK) Native.loadLibrary("你的项目绝对路径/HCNetSDK", HCNetSDK.class);  //你的项目绝对路径指 D:\Workspace\ClientDemo-NetBeansPro

 
 
  • 1

更改

PlayCtrl INSTANCE = (PlayCtrl) Native.loadLibrary("PlayCtrl", PlayCtrl.class);

 
 
  • 1

PlayCtrl INSTANCE = (PlayCtrl) Native.loadLibrary("你的项目绝对路径/PlayCtrl.dll", PlayCtrl.class);  //注意此处的PlayCtrl必须加dll后缀,要不然会报错

 
 
  • 1

解决完错误后,再次打开 ClientDemo.java 中的main方法运行一下,终于出现了久违的画面。
在这里插入图片描述
终于成功运行起来了,我们兴致冲冲的点击注册,却提示 注册失败 。这是什么问题?好吧,debug一下,发现此处代码

lUserID = hCNetSDK.NET_DVR_Login_V30(m_sDeviceIP,
                (short) iPort, jTextFieldUserName.getText(), new String(jPasswordFieldPassword.getPassword()), m_strDeviceInfo);

 
 
  • 1
  • 2

中的lUserID返回-1,为啥会返回-1呢,不知道,完全不懂。

排查

SDK库文件拷贝到该目录下.txt 文件中的第4条描述使用NET_DVR_GetLastError错误号判断原因,好吧,我们加上输入打印。

lUserID = hCNetSDK.NET_DVR_Login_V30(m_sDeviceIP,
                (short) iPort, jTextFieldUserName.getText(), new String(jPasswordFieldPassword.getPassword()), m_strDeviceInfo);
System.out.println("注册失败错误码:" + hCNetSDK.NET_DVR_GetLastError());

 
 

打印出来发现返回41。这个41到底代表的哪个错误,好吧,去文档(设备网络SDK编程指南(DVR&NVR).pdf)里面查一下,文档中描述说

错误名称错误值说明
NET_DVR_ALLOC_RESOURCE_ERROR41SDK 资源分配错误

SDK资源分配错误,是不是资源文件没有引用全啊。没办法,给技术支持发邮件吧。技术支持回复将所有的库文件全拷贝到项目路径下。果然是资源没有引用全的原因。

好吧,照搬,把所有文件拷贝进去后,点击注册,成功了! - _ - - _ - - _ -但是,为什么要拷贝那么多啊,那么多文件放在项目下肯定不合适啊,肯定会有文件用不到啊。

总结

经过我的努力,发现只需要将

HCNetSDK.dll
HCCore.dll
HCNetSDKCom文件夹
PlayCtrl.dll
SuperRender.dll
AudioRender.dll
ssleay32.dll
libeay32.dll

 
 

文件和文件夹拷贝到项目目录下,官方的说明里面直接是少了三个dll文件。T_T T_T T_T

最后,如果拷贝以上文件还是报错的话,建议将所有的dll文件全拷贝到项目根目录下。

这就是我运行海康威视官方JAVA SDK DEMO的所有坑,记录一下,让大家少走弯路。

  • 1
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 10
    评论
海康威视是一家专注于视频监控领域的企业,其产品和解决方案被广泛应用于安防监控、安全防护等多个领域。对于使用Spring Boot来运行海康威视Demo,可以按照以下步骤进行: 首先,确保已经安装好Java开发环境和Spring Boot。可以从官方网站下载Java JDK,并且使用任何IDE(如IntelliJ IDEA、Eclipse等)来创建一个Spring Boot项目。 接下来,可以在海康威视的官方开发者网站上找到Demo的相关文档和代码示例。这些示例通常会提供详细的步骤说明和代码示例来帮助开发者快速上手。 在项目中引入海康威视的相关依赖,可以通过Maven或Gradle来管理项目的依赖。根据文档的说明,在项目的配置文件(如application.properties或application.yml)中配置相关的参数,例如IP地址、端口号、用户名、密码等信息。 根据Demo的要求,可以编写相应的代码逻辑来调用海康威视的API接口。根据Demo的示例代码,可以理解和学习如何初始化和使用海康威视的SDK,如登录、获取设备列表、播放视频等。 在项目的启动类中,可以使用Spring Boot的注解来标注和配置相应的类和方法。例如,可以使用@SpringBootApplication来指定项目的入口类,并使用@RestController来定义一个简单的RESTful接口。 最后,通过运行Spring Boot项目,可以在浏览器或Postman等工具中访问相应的接口,验证Demo运行结果。 总结起来,海康威视的Spring Boot运行Demo的核心步骤包括:安装Java开发环境和Spring Boot,获取海康威视Demo的文档和代码示例,引入依赖并配置相关参数,编写逻辑代码调用海康威视API接口,启动项目并验证运行结果。这些步骤可以帮助开发者快速上手并使用海康威视的产品和解决方案。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 10
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值