NB物联网之天翼物联(4)——配置编解码插件

简介: NB物联网之天翼物联(4)——配置编解码插件

前言


前面为大家介绍了编辑码插件的大体结构,本篇为大家详解怎么配置编解码插件上传包的参数!

向大家推荐如何做到电信NB与移动NB兼容


第23条“婚约”


编解码插件上传位置

image.png

上一篇结尾我们说了如果进行插件开发,必须先了解上传插件包的结构和要求,何为“上传包”?

首先,这个“上传包”就在我们下载的demo文件中:

image.png


它指的是把我们写好的编解码插件打成一个jar包,然后再写一个配置文件,这个配置文件的内容与这个jar包相关,与你当前所处的电信平台的产品相关,也就是说配置文件关联你的jar包和当前需要上传jar包的项目!


综上所述,上传的文件会有各种各样的限制,直接上图证明俺不是瞎说的!

image.png

前14条主要约束我们的产品信息完整和配置文件内容,只要按照要求填写就完了!

这里我们不再一条条对了,直接跟大家说需要怎么修改package.zip中的package-info.json文件

首先文件格式如下:

{
    "specVersion":"1.0",
    "fileName":"codec-demo",
    "version":"0.0.1",
    "deviceType":"WaterMeter",
    "manufacturerName":"bcdyd",
    "model":"WaterMeter",
    "description":"codec",
    "platform":"linux",
    "packageType":"CIGPlugin",
    "date":"2019-11-26 08:16:59",
  "ignoreList":[],
    "bundles":[
    {
        "bundleName": "WaterMeter-厂商ID-WaterMeter",
        "bundleVersion": "0.0.1",
        "priority":5,
        "fileName": "WaterMeter-厂商ID-WaterMeter-0.0.1.jar",
        "bundleDesc":"",
        "versionDesc":""
    }]
}

specVersion:不需要修改;

fileName:不需要修改;

version:需要和你的jar包中版本对应,即与项目pom.xml 中的


<version>0.0.1</version>

1

一致;

deviceType:与你平台上的设备类型一致;

manufacturerName:与你平台上的厂商名称一致;

model:与你平台上的产品型号是一致的;

description:不需要修改;

platform:不需要修改;

packageType:不需要修改;

date:不需要修改;

ignoreList:不需要修改;

bundleName:设备类型-厂商ID-产品型号;

bundleVersion:与version一致;

priority:不需要修改;

fileName:jar包名字;

bundleDesc:不需要修改;

versionDesc:不需要修改;

修改项目中的pom文件:

大体结构:

<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
  <modelVersion>4.0.0</modelVersion>
  <groupId>com.thrid.party</groupId>
  <!-- 请修改为你的编解码插件的名字,命名规范:设备类型-厂商ID-设备型号,例如:WaterMeter-Huawei-NBIoTDevice -->
  <artifactId>WaterMeter-Huawei-NBIoTDevice</artifactId>
  <version>1.0.0</version>
  <!-- 请检查这里的值为bundle,不能为jar -->
  <packaging>bundle</packaging>
  <properties>
    <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
    <junit.version>4.11</junit.version>
    <fasterxml.jackson.version>2.7.4</fasterxml.jackson.version>
    <felix.maven.plugin.version>2.5.4</felix.maven.plugin.version>
    <json.lib.version>2.4</json.lib.version>
    <m2m.cig.version>1.3.1</m2m.cig.version>
    <slf4j.api.version>1.7.6</slf4j.api.version>
    <basedir>./</basedir>
  </properties>
  <dependencies>
    <!-- 单元测试使用 -->
    <dependency>
      <groupId>junit</groupId>
      <artifactId>junit</artifactId>
      <version>${junit.version}</version>
    </dependency>
    <!-- 日志使用 -->
    <dependency>
      <groupId>org.slf4j</groupId>
      <artifactId>slf4j-api</artifactId>
      <version>${slf4j.api.version}</version>
    </dependency>
    <!-- 转换JSON使用,必须 -->
    <dependency>
      <groupId>com.fasterxml.jackson.core</groupId>
      <artifactId>jackson-databind</artifactId>
      <version>${fasterxml.jackson.version}</version>
    </dependency>
    <!-- Huawei提供的编解码接口,必须 -->
    <!-- systemPath请替换成你本地的目录 \codecDemo\lib\com.huawei.m2m.cig.tup-1.3.1.jar -->
    <dependency>
      <groupId>com.huawei</groupId>
      <artifactId>protocal-jar</artifactId>
      <version>1.3.1</version>
      <scope>system</scope>
      <systemPath>${basedir}/lib/com.huawei.m2m.cig.tup-1.3.1.jar</systemPath>
    </dependency>
  </dependencies>
  <build>
    <plugins>
      <!-- 编码需要使用JDK1.8版本 -->
      <plugin>
        <groupId>org.apache.maven.plugins</groupId>
        <artifactId>maven-compiler-plugin</artifactId>
        <configuration>
          <source>1.8</source>
          <target>1.8</target>
        </configuration>
      </plugin>
      <!-- OSGI规范打包配置 -->
      <plugin>
        <groupId>org.apache.felix</groupId>
        <artifactId>maven-bundle-plugin</artifactId>
        <version>${felix.maven.plugin.version}</version>
        <extensions>true</extensions>
        <configuration>
          <buildDirectory>./target</buildDirectory>
          <archive>
            <addMavenDescriptor>false</addMavenDescriptor>
          </archive>
          <instructions>
            <Bundle-RequiredExecutionEnvironment>J2SE-1.5</Bundle-RequiredExecutionEnvironment>
            <Bundle-Activator></Bundle-Activator>
            <Service-Component>OSGI-INF/*</Service-Component>
            <!-- 请修改为你的编解码插件的名字,命名规范:设备类型-厂商ID-设备型号,例如:WaterMeter-Huawei-NBIoTDevice -->
            <Bundle-SymbolicName>WaterMeter-Huawei-NBIoTDevice</Bundle-SymbolicName>
            <Export-Package></Export-Package>
            <Import-Package>
              org.slf4j,
              org.slf4j.spi,
              org.apache.log4j.spi,
              com.huawei.m2m.cig.tup.modules.protocol_adapter,
              com.fasterxml.jackson.databind,
              com.fasterxml.jackson.databind.node
            </Import-Package>
            <!-- 除junit,slf4j-api,jackson-databind,protocal-jar, 其他所有的依赖包,必须把包对应的artifactId填入Embed-Dependency。artifactId之间以逗号分隔。 -->
            <Embed-Dependency>
              <!-- json-lib -->
            </Embed-Dependency>
          </instructions>
        </configuration>
        <executions>
          <execution>
            <id>generate-resource</id>
            <goals>
              <goal>manifest</goal>
            </goals>
          </execution>
        </executions>
      </plugin>
    </plugins>
  </build>
</project>

按照注释修改完成就ok了~!

修改maven配置文件:


在如图所示的位置:


<?xml version="1.0" encoding="UTF-8"?>
<scr:component xmlns:scr="http://www.osgi.org/xmlns/scr/v1.1.0" immediate="true" name="com.Huawei.NBIoTDevice.WaterMeter.ProtocolAdapterImpl">
    <implementation class="com.Huawei.NBIoTDevice.WaterMeter.ProtocolAdapterImpl"/>
    <service>
  <provide interface="com.huawei.m2m.cig.tup.modules.protocol_adapter.IProtocolAdapter" />
  </service>
</scr:component>


这里需要重点注意一下,第21条22条23条就是说的这个文件!

image.png

上面说的name也好class也好都是项目中ProtocolAdapterImpl.java文件的访问路径,这里还有一点需要注意,就是本项目的包名:

image.png

如上题所示我们的包名不是随便取的,必须是com.厂商名称.产品型号.设备类型

完成以上工作,就完成了编解码项目的所有配置工作,下一步就是找到程序被调用的入口及编写窍门了!!

编解码插件编写入口!


相关实践学习
钉钉群中如何接收IoT温控器数据告警通知
本实验主要介绍如何将温控器设备以MQTT协议接入IoT物联网平台,通过云产品流转到函数计算FC,调用钉钉群机器人API,实时推送温湿度消息到钉钉群。
阿里云AIoT物联网开发实战
本课程将由物联网专家带你熟悉阿里云AIoT物联网领域全套云产品,7天轻松搭建基于Arduino的端到端物联网场景应用。 开始学习前,请先开通下方两个云产品,让学习更流畅: IoT物联网平台:https://iot.console.aliyun.com/ LinkWAN物联网络管理平台:https://linkwan.console.aliyun.com/service-open
相关文章
|
3月前
|
运维 安全 物联网
物联网:NB卡在使用过程中存在的一些限制和需要特别注意的操作事项
物联网NB卡(通常指的是窄带物联网(NarrowBand Internet of Things, NB-IoT)卡)是专为物联网设备设计的无线通信模块,主要用于连接物联网设备与移动网络,实现远程数据交换和控制。然而,在使用物联网NB卡时,确实存在一些限制和操作上的考虑因素。以下是一些主要的限制和操作注意事项:
|
3月前
|
物联网
物联网:NB卡是否支持2/3/4G网络
在讨论“NB卡是否支持2/3/4G网络”的问题时,我们首先需要明确“NB卡”指的是什么。在通信领域中,“NB卡”通常指的是支持NB-IoT(Narrowband Internet of Things,窄带物联网)技术的SIM卡或模块。NB-IoT是一种专为物联网设计的窄带无线通信技术,它基于现有的蜂窝网络进行构建,但专注于低功耗广域网(LPWAN)应用。
|
3月前
|
传感器 监控 安全
物联网:NB卡的应用场景
物联网NB-IoT(窄带物联网)卡作为一种低功耗、广覆盖、大连接的物联网通信技术,广泛应用于各种需要远程监控、数据传输和智能管理的场景中。以下是一些NB-IoT卡的具体应用场景及其操作概述:
|
3月前
|
网络协议 物联网 数据安全/隐私保护
物联网卡:什么是NB卡
对于物联网NB卡的操作,我们可以从多个方面进行详细阐述,包括其基本概念、选购注意事项、配置过程以及使用注意事项等。以下是对物联网NB卡操作的全面指导:
|
6月前
|
机器学习/深度学习 传感器 边缘计算
云端物联:智能物联网平台引领数字化转型之路
云上智能物联网平台正在成为推动数字化转型的重要力量。它不仅为企业带来了新的商业模式和发展机会,也为消费者提供了更加便捷和个性化的服务体验。
|
8月前
|
SQL Prometheus 监控
助力工业物联网,工业大数据之服务域:node_exporter插件【三十七】
助力工业物联网,工业大数据之服务域:node_exporter插件【三十七】
86 1
|
安全 物联网
阿里云产品体系分为6大分类——物联网——分为7类——物联安全
阿里云产品体系分为6大分类——物联网——分为7类——物联安全自制脑图
164 1
|
编解码 物联网 测试技术
NB物联网之天翼物联(7)——一次性通过电信NB平台自助测试
NB物联网之天翼物联(7)——一次性通过电信NB平台自助测试
NB物联网之天翼物联(7)——一次性通过电信NB平台自助测试
|
编解码 JSON 物联网
NB物联网之天翼物联(6)——移动电信NB的区别与兼容开发
NB物联网之天翼物联(6)——移动电信NB的区别与兼容开发
NB物联网之天翼物联(6)——移动电信NB的区别与兼容开发
|
2月前
|
存储 安全 物联网
政府在推动物联网技术标准和规范的统一方面可以发挥哪些作用?
政府在推动物联网技术标准和规范的统一方面可以发挥哪些作用?
120 50

相关产品

  • 物联网平台