可穿戴设备(CC2541)上微信(1)

原创 2015年07月07日 15:55:34

      从去年开始接触 BLE,当时直接玩的是 CC2541,还好有人带,要不然真是撸死也撸不过,虽然还有很多东西比如透传、加解密之类的搞不懂,但是起码能和 APK 正常收发数据,最开始上的是京东的 APK,很蛋疼,京东的 APK 一点都不智能,也不傻瓜,但是好歹给的协议文档写的比较清楚,一步一步来就差不多可以了,最后案子挂了,也就没有做下去的动力了。。。                  

      ps:案子挂了最讨厌了。。。白费功夫。。。


     现在上面需要人上微信。。。BLE 这部分只有我做过 CC2541 的,所以只能我去上了。。。不知道自己够不够硬。。。能不能上得了。。。先试试吧。。。

     ps:我:我行么。。。上不去啊。。。疑问

            老板:让你上就得上,上不了也得上。。。奋斗

            我:微信我来了。。。洗白白等我。。。羡慕



     CC2541 上微信有两种,一个是精简协议,一个是完整协议,精简协议没有身份验证和加解密,而且要使用特殊的 APK 来调试,完整版的 APK 就是使用微信,而且身份验证和加解密都需要,广播包和扫描返回包相同,但是特征值也不同。


CC2541 上微信的 IAR 工程中有一个 pb_example.c 和 pb_example.h

pb_example.h 中有以下两个函数

extern uint8_t Pack_Data(uint16 EmCmdIDData) ;
extern uint8_t UnPack_Data(uint8_t *buf, int buf_len) ;

uint8_t Pack_Data(uint16 EmCmdIDData) ;

文件加密打包副程式

回傳值:加密打包的結果

              PACK_OK                                        0

              回傳打包OK

              ERR_EMCMDID                             1

              回傳錯誤的命令號

              ERR_LEN                                         2

              回傳錯誤的長度

EmCmdIDData:

藍牙設備傳給微信或後台的命令號

             ECI_req_auth                                   10001

             登录包

             ECI_req_sendData                           10002

             蓝牙設備發送數據給微信或是廠商

             ECI_req_init                                    10003

             初始化包

產生數據:

             PackProtobufData[PACKLEN];

            打包好的數據包

            PackProtobufLen ;

            要送出的資料長度


uint8_t UnPack_Data(uint8_t*buf,int buf_len) ;

文件解密解包副程式

回傳值:解包的回傳值

             UNPACK_OK                                   0

             回傳解包 OK

             UNPACK_CONTINUOUS                     1

             回傳尚在解包表示資料未收完

             ERR_MAGICNUMBER                  2

             回傳錯誤的定長包頭第一筆資料

             ERR_BVER                                      3

             回傳錯誤的包格式版本號

             ERR_UNPACKLEN                         4

             回傳錯誤的資料長度

             PUSH_REC_DATA                          81

             回傳表示有收到微信或是廠商發送數據給藍牙設備

             PUSH_SWITCHVIEW                    82

             回傳表示進入或退出界面

             PUSH_SWITCHBACKGROUD            83

             回傳切換後台

*buf:解包解密的數據表

buf_len :要解包的資料長度


这两个函数不需要知道详细工作原理,只要知道它的作用是加密和解密就好了,但是要清楚地知道在哪里调用,什么时候调用。。。

ps:这都不知道你还干个屁啊。。。


版权声明:本文为博主原创文章,未经博主允许不得转载。

相关文章推荐

Ogre全屏下自制输入法状态框的实现~~~

思路一,使用新的支持win7的DXD9 的Overlay http://msdn.microsoft.com/en-us/library/dd797814(VS.85).aspx 加钩子思路二,直接用...

可穿戴设备(CC2541)上微信(4)

Source Code 加密

可穿戴设备(CC2541)上微信(7)

一、 微信客户端和 BLE 设备通信流程 1. 微信通过聊天窗口向 BLE 设备发送数据,数据流程如下: 微信客户端 ---> 微信服务器 ---> 客户服务器 ---> 微信服务器 ---> 微信客...

CC2541 连接微信(1)——微信 AirSync 和 微信精简协议 介绍

微信 AirSync 和 微信精简协议 介绍

可穿戴设备(CC2541)上微信(3)

蓝牙设备读写过程

可穿戴设备(CC2541)上微信(2)

adverData 和 scanResponseData

可穿戴设备(CC2541)上微信(6)

读取设备的 MAC 地址: GAPRole_GetParameter(GAPROLE_BD_ADDR, ownAddress);#define GAPROLE_BD_ADDR             ...

可穿戴设备(CC2541)上微信(5)

1. 当 BLE 设备与微信连接后,微信客户端通过下面的程序向 BLE 设备发送数据: static bStatus_t wechatIOT_WriteAttrCB( uint16 connHandl...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

(最多只允许输入30个字)