收藏官网首页
查看: 21432|回复: 0

[经验分享] APP与设备之间的数据透传解析

32

主题

39

帖子

376

积分

中级会员

Rank: 3Rank: 3

积分
376
跳转到指定楼层
楼主
发表于 2016-12-23 15:38:46 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
免费使用STM32、APP自动代码生成工具
本帖最后由 Genius 于 2016-12-23 15:58 编辑

导读:本文先介绍消息透传,再介绍如何使用机智云设备接入SDK来进行APP与设备之间的数据透传。在APP和MCU之间,有两种数据透传方式: 利用“扩展类型”数据点进行透传;不定义数据点直接进行数据透传,即纯透传。



目前的消息推送方式主要有两种:通知和透传。
什么是透传?透传即是透明传送,即传送网络无论传输业务如何,只负责将需要传送的业务传送到目的节点,同时保证传输的质量即可,而不对传输的业务进行处理。透传消息,就是消息体格式及内容,对于传递的通道来说是不去过问的,通道只负责消息的传递,对消息不做任何处理,当客户端接收到透传消息后,由客户端自己来决定如何处理消息。正是因为透传消息可以自定义消息体,也可以自定义消息的展示方式及后续动作处理,所以弥补了通知栏消息的一些不足之处(通知栏消息是直接展示出来,相关的动作客户端无法捕获到)。


透传消息主要有如下几个方面的特点
1. 后台处理,用户无感知。
2. 前台展示,提醒用户。
3. 展示的多样化。

整个透传消息的流程如下:根据个推提供的API接口或在个推开发者平台上推送透传消息,个推服务端接收到推送的消息后,不做任何处理,直接发送给目标用户。当客户端SDK接收到透传消息后,以广播方式发送给客户端,客户端在配置的第三方BroadReceiver里接收到透传消息后进行处理。


透传消息的消息体,可以根据不同的需求传递不同的参数或格式。如传递一个简单的字符串,或传递一个Json字符串,里面根据需求传递需要的字段。

用户无感知的透传,如:更新相关信息,在主界面中相关栏位用红点标识进行弱提醒,推送一条命令用来检测用户是否有登录等。通知栏消息虽然方便的提醒用户,但也在一定程度上给用户带来了打扰,用户无感知的消息推送有时效果会更好。
用户有感知的透传:把透传消息处理成通知栏展示出来,提醒用户方便点击查看相关信息(如个人帐单信息),直接打开应用或跳转到指定的应用界面中(根据透传消息的相关参数来判断跳转到哪一个指定的界面,相关参数传递要打开的界面的类名或Intent即可)等。对于开发者,处理成通知栏的相关事件也是可以捕获的,如通知栏的展示、点击等事件都可以进行捕获,以方便进行后续的操作。

因透传消息可以自己处理成通知栏内容展示,所以通知栏的样式也可以根据需求来做对应的改变。在Android 4.4及以上的系统,通知栏可以是样式丰富的通知栏,放入图片和视频等;可以展示普通的通知,也可以展示多样化的通知。


下面,我将介绍如何使用机智云设备接入SDK来进行APP与设备之间的数据透传。在APP和MCU之间,有两种数据透传方式:

  • 利用“扩展类型”数据点进行透传
  • 不定义数据点直接进行数据透传,即纯透传


扩展类型数据点透传1.定义数据点
在机智云产品管理中的数据点中定义一个拓展类型的数据点,如上图所示:
定义数据长度为60个byte(透传情况下,数据长度暂时支持900字节内数据传输)。

2.设备上报数据协议说明
设备MCU按照数据点的定义格式上报透传数据,在完成新产品的定义后,每个新产品都有相应的串口通信协议文档,文档下载路径如下图所示:
在串口通信协议文档文档的4.9部分则有MCU上报数据的格式,如下图:
图中的dev_status(60B)即为需要透传的数据。

3.SDK回调接口说明
APP端接收到MCU上报数据的回调接口:didReceiveData,判断result为GizWifiErrorCode.GIZ_SDK_SUCCESS,则接收到的数据可能为普通数据点或者扩展数据点。

4.APP接收数据代码示例
Andriod接收到MCU上报拓展数据类型代码示例:

  1. final protected static char[] hexArray = "0123456789ABCDEF".toCharArray();

  2. // 将16进制的byte转为string,比如byte值为{0x62,0x63},那么将转为“6263”
  3. public static String bytesToHex(byte[] bytes) {
  4.                 char[] hexChars = new char[bytes.length * 3];
  5.                 for (int j = 0; j < bytes.length; j++) {
  6.                         int v = bytes[j] & 0xFF;
  7.                         hexChars[j * 3] = hexArray[v >>> 4];
  8.                         hexChars[j * 3 + 1] = hexArray[v & 0x0F];
  9.                         hexChars[j * 3 + 2] = ' ';
  10.                 }
  11.                 return new String(hexChars);
  12. }

  13. @Override
  14. protected void didReceiveData(GizWifiErrorCode result, GizWifiDevice device,
  15.                         ConcurrentHashMap<String, Object> dataMap, int sn) {

  16.         if (result == GizWifiErrorCode.GIZ_SDK_SUCCESS) {
  17.         // 普通数据点类型,有布尔型、整形和枚举型数据,该种类型一般为可读写
  18.                 if (dataMap.get("data") != null) {
  19.                         ConcurrentHashMap<String, Object> map = (ConcurrentHashMap<String, Object>) dataMap.get("data");
  20.                         // 扩展数据点,key为"kuozhan"
  21.                         byte[] bytes = (byte[]) map.get("kuozhan");
  22.                         String string = bytesToHex(bytes);
  23.                         Toast.makeText(this, string, Toast.LENGTH_SHORT).show();
  24.                 }
  25.         }
  26. }
复制代码

[/table]

iOS接收到MCU上报拓展数据类型代码示例:
[/table]
- (void)device\"\"GizWifiDevice *)device didReceiveData\"\"NSError *)result data\"\"NSDictionary *)dataMap withSN\"\"NSNumber *)sn
{
    if (result.code == GIZ_SDK_SUCCESS)
    {
        NSLog(@"接收到数据");
        NSDictionary *data = dataMap[@"data"];
        NSString *kuozhan = data[@"kuozhan"];
            
        NSLog(@"dataMap = %@", dataMap);
        NSLog(@"kuozhan = %@", kuozhan);
        
    }
}
5.设备上报数据案例
案例:根据数据点上报格式上报数据:
FF FF 00 42 05 00 00 00 04 01 02 03 04 05 06 07 08 09 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 78
注意定义的扩展数据类型为60个字节,因此上报数据的时候也一定要保证上报命令中“设备状态”字节数为60个字节,否则APP端将不会收到数据。多余的数据可以进行补零操作。
APP端接收到的dataMap字典中有一个”kuozhan”的key,对应的值即为透传的数据。
dataMap = {
    alerts={
    };
    data ={
        kuozhan = <01020304 05060708 09000000 00000000 00000000 00000000 00000000 00000000 00000000 00000000 00000000 00000000 00000000 00000000 00000000>;
    };
    faults={
    };
}
6.APP下发数据代码示例
APP在GizWifiDevice类的write接口中,按照数据点定义发送扩展数据。
Andriod下发拓展数据类型命令代码示例:

  1. byte[] input1 = { 0x11, 0x22, 0x33, 0x44, 0x55, 0x66, 0x77 };
  2. // byte[] input2 = { 11, 22, 33, 44, 55, 66, 77, 88, 99};
  3. ConcurrentHashMap<String, Object> dataMap = new ConcurrentHashMap<String, Object>();
  4. dataMap.put("kuozhan", input1);
  5. device.write(dataMap, 0);
复制代码
iOS下发拓展数据类型命令代码示例:
[table=98%]
  1. <div class="blockcode"><blockquote>char input1[7] = {0x11, 0x22, 0x33, 0x44, 0x55, 0x66, 0x77};
  2. // char input2[7] = {11, 22, 33, 44, 55, 66, 77};
  3.     NSData* data = [NSData dataWithBytes:input1 length:sizeof(input1)];
  4.     NSDictionary *request = @{@"kuozhan": data};
  5.     [self.device write:request withSN:44];
复制代码


上述代码中,input1与input2的透传结果是不一样的,input1中定义的是十六进制的数值,input2中则是十进制的数值。如果使用input1中0x11的值下发给设备,那么设备将收到0x11的十六进制值,如果使用input2中11的值下发给设备,那么设备收到将是0x0b(十进制11对应十六进制b)。使用input1下发设备,MCU收到的数据为:
FF FF 00 43 03 45 00 00 01 01 11 22 33 44 55 66 77 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 69

无数据点透传1.设备上报数据协议说明
MCU上报数据的格式如下表所示,包长度(len)是指从命令开始一直到校验和的字节长度(包括命令和校验和)。dev_status是需要透传数据,可以设置任意长度,但是暂时支持900B内传输。
如设备上报指令:FF FF 00 0D 05 00 00 00 06 11 22 33 44 55 66 77 F4 ;那么透传的数据为11 22 33 44 55 66 77

2.SDK回调接口说明
APP端接收到MCU上报数据的回调接口: didReceiveData,判断result为GizWifiErrorCode.GIZ_SDK_SUCCESS,则表示接收到数据成功,回传参数的dataMap 中的“binary”字段的值为透传数据。

3.APP接收数据代码示例
Andriod接收MCU无数据点上报代码示例:
[table=98%]
@Override
protected void didReceiveData(GizWifiErrorCode result, GizWifiDevice device,ConcurrentHashMap<String, Object> dataMap, int sn) {
        if (result == GizWifiErrorCode.GIZ_SDK_SUCCESS) {
                // 透传数据,无数据点定义,适合开发者自行定义协议自行解析
                if (dataMap.get("binary") != null) {
                byte[] binary = (byte[]) dataMap.get("binary");
                Log.i("info", "Binary data:" + bytesToHex(binary));
                        // 收到后面需要自行解析
                }
        }
}

iOS接收MCU无数据点上报代码示例:
  1. - (void)device:(GizWifiDevice *)device didReceiveData:(NSError *)result data:(NSDictionary *)dataMap withSN:(NSNumber *)sn
  2. {
  3.     if (result.code == GIZ_SDK_SUCCESS)
  4.     {
  5.         NSLog(@"接收到数据");
  6.         NSLog(@"dataMap = %@", dataMap);
  7.         
  8.         NSString *binary = dataMap[@"binary"];
  9.         // 后面需要自行对binary数据进行解析
  10.         }
  11. }
复制代码

如MCU上报:FF FF 00 0D 05 00 00 00 06 11 22 33 44 55 66 77 F4
则APP将打印: Binary data:11 22 33 44 55 66 77

4.APP下发数据代码示例
APP在GizWifiDevice类的write接口中,发送的json格式为:{“binary”: “xxxxxx”};MCU接收的数据格式如下:

Andriod下发无数据点透传数据代码示例:
byte[] input1 = { 0x11, 0x22, 0x33, 0x44, 0x55, 0x66, 0x77 };
ConcurrentHashMap<String, Object> dataMap = new ConcurrentHashMap<String, Object>();
dataMap.put("binary", input1);
device.write(dataMap, 0);
iOS下发无数据点透传数据代码示例:
  1. char input1[7] = {0x11, 0x22, 0x33, 0x44, 0x55, 0x66, 0x77};
  2. // char input2[7] = {11, 22, 33, 44, 55, 66, 77};   
  3. NSData* data = [NSData dataWithBytes:input1 length:sizeof(input1)];
  4. NSDictionary *request = @{@"binary": data};   
  5. [self.device write:request withSN:0];
复制代码

MCU接收到的APP下发数据格式(即以上bytes数组下发后,MCU接收到的数据):
FF FF 00 0D 03 16 00 00 05 11 22 33 44 55 66 77 07



原文:http://docs.gizwits.com/zh-cn/AppDev/SDK%E6%95%B0%E6%8D%AE%E9%80%8F%E4%BC%A0%E6%96%B9%E6%B3%95%E8%A7%A3%E6%9E%90.html
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

加入Q群 返回顶部

版权与免责声明 © 2006-2024 Gizwits IoT Technology Co., Ltd. ( 粤ICP备11090211号 )

快速回复 返回顶部 返回列表