微信小程序数据接收

1.微信小程序蓝牙模块中的

复制代码
wx.onBLECharacteristicValueChange 

回调函数有时候一个数据包会分多个数据包回调,有时候多个数据包会合并成一个数据包回调,如果接收到数据包就处理业务,分拆的和合并的数据都会因为解析失败,导致业务无法正常进行。

2.数据包设计格式为7b开头,随后两位代表整体长度(7b用于鉴定数据合法性,长度用于控制后续数据处理)。

3.数据包开头不为7b开头则视为非法数据丢弃。

4.数据包7b开头长度不足,则等后续数据进行拼接后再次处理。

5.数据包7b开头长度溢出(正好视为溢出0位),则把长度正常部分交给业务处理,随后把溢出部分再次进入第2步处理(递归)。

6.第5步采用了递归,但是每次受理数据都会截断,总有截断到空串的时候,所以不用担心递归会造成死循环。

复制代码
const bufferHead = '7b'; //缓冲区头部
const onBLECharacteristicValueChange = (cb) => {
    //首次监听清空
    let bufferString = "";
    const handleHex = (str, strHex) =>{
      console.log("BLE收到消息:"+strHex);
      //1.检验缓冲区数据是否合法,合法则保留不合法则丢弃
      if(bufferString.length > 0 && bufferString.slice(0,2) !== bufferHead){
        console.log("BLE缓冲区不合法丢弃:"+bufferString);
        bufferString = "";
      }
      //2.缓冲区拼接新数据(缓冲区有长度直接拼,无长度新数据合法才能拼(新数据为空或者7b开头为合法))
      if(bufferString.length > 0 || strHex === "" || strHex.slice(0,2) === bufferHead){
        console.log("BLE缓冲区合法拼接:"+bufferString+"和"+strHex);
        bufferString += strHex;
      }
      //3.取数据的合法长度
      let bufferLength = 4; //合法字节至少四位,因为第三位和第四位代表长度
      if(bufferString.length >= 4){
        bufferLength = parseInt(bufferString.slice(2,4), 16)*2;
      }
      //4.长度充足截取有效内容,剩余部分存入缓冲区
      if(bufferString.length >= bufferLength){
        const value = bufferString.slice(0,bufferLength);
        bufferString = bufferString.slice(bufferLength);
        console.warn("BLE缓冲区溢出分解为:"+value+"和"+bufferString);
        cb(str, value);
        //5.黏包情况继续处理剩余部分,若剩余部分有完整包则能继续处理业务
        if(bufferString.length >0){
          handleHex(str, "");
        }
      }else{
        console.log("BLE缓冲区长度缺失:"+(bufferLength-bufferString.length));
      }
    }
    wx.onBLECharacteristicValueChange((res) => {
        let x = new Uint8Array(res.value);
        let strHex = ""
        let str = ""
        for (let i = 0; i < x.length; i++) {
            strHex = strHex + x[i].toString(16).padStart(2, "0")
        }
        handleHex(str, strHex);
    })
}
相关推荐
疯狂的沙粒2 小时前
uniapp 开发企业微信小程序时,如何在当前页面真正销毁前或者关闭小程序前调用一个api接口
微信小程序·小程序·uni-app
山河故人1632 小时前
UniApp微信小程序自定义导航栏实现
微信小程序·uni-app·notepad++
魔术师ID3 小时前
微信小程序学习目录
学习·微信小程序·小程序
一蓑烟雨,一任平生9 小时前
在h5端实现录音发送功能(兼容内嵌微信小程序) recorder-core
微信小程序·小程序
说私域11 小时前
多级体验体系构建:基于开源AI智能客服与AI智能名片的S2B2C商城小程序体验升级路径研究
人工智能·小程序·开源·零售
^Rocky13 小时前
微信小程序(uniapp)对接腾讯云IM
微信小程序·uni-app·腾讯云
栈狮13 小时前
Uniapp+UView+Uni-star打包小程序极简方案
小程序·uni-app
格调UI成品17 小时前
政务小程序TOP3交互设计分析:便民服务的隐藏心机
microsoft·小程序·政务
声声codeGrandMaster18 小时前
uni-app开发特殊社交APP
小程序·uni-app·web app
—Qeyser19 小时前
让 Deepseek 写一个尺码计算器
微信小程序·小程序·deepseek