- 最新动态
- 产品介绍
- 快速入门
- 用户指南
- 开发指南
-
API参考
- 北向API参考
- 北向JAVA SDK API参考
- 北向PHP SDK API参考
- 北向Python SDK API参考
- Agent Lite API参考(Android)
- Agent Lite API参考(C)
- Agent Lite API参考(Java)
- MQTT接口参考
-
常见问题
- 常见问题导航
- 产品规格
- 产品使用
-
二次开发
-
产品开发常见问题
- Profile定义
- 插件开发
-
设备开发
- 在物联网平台注册完设备,真实设备无法接入物联网平台
- 终端设备接入物联网平台时,出现513错误
- 物联网平台支持的DTLS加密算法有哪些
- AT+CGDCONT=1,"IP","CTNB" 中 CTNB 是什么
- 设备如何选择PSM、DRX、eDRX模式
- 设备收不到平台下发的命令
- 设备已经上报数据,但是物联网平台未收到
- 设备上报了数据,且日志无报错,但在历史数据中没有数据
- 设备收到命令需要多长时间
- 设备上报数据后,收不到物联网平台回复的数据上报响应
- 设备在一个位置上报数据成功,在另一个位置上报失败
- 设备上报了命令执行结果,但是命令状态未切换为成功
- 物联网平台支持大小端模式切换吗
- 省电模式DRX模式,设备1-2天未上报数据,下发命令失败
-
应用开发常见问题
-
接口调用
- 本地可以成功调用物联网平台的鉴权接口,但是在应用服务器调用失败
- 应用服务器调用接口报错如何定位
- 在线应用模拟器下发命令失败
- 模拟器下发命令成功,调用API下发命令失败
- 应用服务器下发命令失败,收到403的错误,提示回调地址冲突
- 应用服务器如何下发缓存命令
- 历史命令中显示的超期是什么意思
- 物联网平台下发命令有重发机制吗
- 历史命令中显示超时是什么意思
- 平台能批量下发命令吗
- 平台接口只能用Java调用吗
- 物联网平台的命令状态总共有几种
- 调用注册设备接口失败
- 之前调用接口成功,一段时间后参数不变,但是调用接口失败
- 之前对单个设备下发命令成功,一段时间后下发命令失败
- 历史数据中有数据,但是调用查询设备历史数据接口没有返回值
- 通过调用接口在物联网平台注册设备,一段时间后注册设备被平台删除
-
订阅与推送
- 调用订阅接口时,提示回调地址不合法
- 调用删除单个订阅接口时,subscriptionId如何获取
- 应用服务器收不到平台推送的数据
- 如何导出https推送证书
- 设备数据变化通知和批量设备数据变化通知的区别是什么
- 应用服务器如何获取设备的IMEI号
- 应用服务器收到数据,但是平台显示推送失败
- 历史数据中有数据,但是有时能推送到应用服务器,有时推不到
- 应用服务器如何获取物联网平台推送消息时使用的地址
- 物联网平台是否具有重推机制
- 应用服务器如何收到命令状态变化的通知
- 已订阅消息确认通知和命令响应通知,为何应用服务器收不到推送消息
- 物联网平台只支持HTTPS的回调地址吗
- 在同一个应用下,物联网平台可以将不同设备上报的数据,推送到两个服务器吗
- 订阅地址可以用域名吗
- 回调地址可以修改吗
- 调用订阅接口时,回调地址如何获取
-
接口调用
- 软/固件升级常见问题
- 其他常见问题
-
产品开发常见问题
- 通用参考
展开导读
链接复制成功!
编解码插件打包
本节介绍编解码完成后如何打包和制作插件包。
编解码Maven打包
完成插件编程后使用Maven进行打包,Windows中步骤如下:
- 打开DOS窗口,进入“pom.xml”所在的目录。
- 输入maven打包命令:mvn package。
- DOS窗口中显示“BUILD SUCCESS”后,打开与“pom.xml”目录同级的target文件夹,获取打包好的jar包。
jar包命名规范为:设备类型-厂商ID-设备型号-版本.jar,例如:WaterMeter-Huawei-NBIoTDevice-version.jar。
图1 Jar包结构图- com目录存放的是class文件。
- META-INF下存放的是OSGI框架下的jar的描述文件(根据pom.xml配置生成的)。
- OSGI-INF下存放的是服务配置文件,把编解码注册为服务,供平台调用(只能有一个xml文件)。
- 其他jar是编解码引用到的jar包。
制作插件包
- 新建文件夹命名为“package”,包含一个“preload/”子文件夹。
- 将打包好的jar包放到“preload/”文件夹。
图2 插件包结构图
- 在“package”文件夹中,新建“package-info.json”文件。该文件的字段说明和模板如下:
说明:
“package-info.json”需要以UTF-8无BOM格式编码。仅支持英文字符。
表1 “package-info.json”字段说明 字段名
字段描述
是否必填
specVersion
描述文件版本号,填写固定值:"1.0"。
是
fileName
软件包文件名,填写固定值:"codec-demo"
是
version
软件包版本号。描述package.zip的版本,请与下面的bundleVersion取值保持一致。
是
deviceType
设备类型,与Profile文件中的定义保持一致。
是
manufacturerName
制造商名称,与Profile文件中的定义保持一致,否则无法上传到平台。
是
model
产品型号,与Profile文件中的定义保持一致。
是
platform
平台类型,本插件包运行的IoT平台的操作系统,填写固定值:"linux"。
是
packageType
软件包类型,该字段用来描述本插件最终部署的平台模块,填写固定值:"CIGPlugin"。
是
date
出包时间,格式为:"yyyy-MM-dd HH-mm-ss",如"2017-05-06 20:48:59"。
否
description
对软件包的自定义描述。
否
ignoreList
忽略列表,默认为空值。
是
bundles
一组bundle的描述信息。
说明:
bundle就是压缩包中的jar包,只需要写一个bundle。
是
表2 bundles的字段说明 字段名
字段描述
是否必填
bundleName
插件名称,和上文中pom.xml的Bundle-SymbolicName保持一致。
是
bundleVersion
插件版本,与上面的version取值保持一致。
是
priority
插件优先级,可赋值默认值:5。
是
fileName
插件jar的文件名称。
是
bundleDesc
插件描述,用来介绍bundle功能。
是
versionDesc
插件版本描述,用来介绍版本更迭时的功能特性。
是
package-info.json文件模板:
{ "specVersion":"1.0", "fileName":"codec-demo", "version":"1.0.0", "deviceType":"WaterMeter", "manufacturerName":"Huawei", "model":"NBIoTDevice", "description":"codec", "platform":"linux", "packageType":"CIGPlugin", "date":"2017-02-06 12:16:59", "ignoreList":[], "bundles":[ { "bundleName": "WaterMeter-Huawei-NBIoTDevice", "bundleVersion": "1.0.0", "priority":5, "fileName": "WaterMeter-Huawei-NBIoTDevice-1.0.0.jar", "bundleDesc":"", "versionDesc":"" }] }
- 选中“package”文件夹中的全部文件,打包成zip格式(“package.zip”)。
说明:
“package.zip”中不能包含“package”这层目录。