App Inventor 2 BLE扩展源码分析 - WriteBytes vs WriteStrings 23字节硬编码问题

简介: 分析MIT App Inventor BLE扩展源码,发现WriteStrings方法存在23字节硬编码截断问题(BLE 4.0最小MTU),而WriteBytes走Integer路径无此限制。本文详细分析根因并提供三种解决方案。

一、问题背景

用户反馈:WriteBytes 发送字符串硬件能收到,Writestrings 发送却收不到。

同样的字符串数据,通过 WriteBytes 方法发送时硬件正常接收,但通过 Writestrings 方法发送时硬件收不到或收到截断数据。

源码仓库: mit-cml/appinventor-extensions (extension/bluetoothle 分支)

关键文件:

  • BluetoothLE.java(2975行)-- 公开API层
  • BluetoothLEint.java(3165行)-- 内部实现层

二、核心发现:23字节硬编码限制

位于 BLEWriteOperation.write() 方法第678-690行:

if (mClass == String.class) {
    byte[] str = ((String) data.get(0)).getBytes();
    final int len = Math.min(23, str.length + (nullTerminateStrings ? 1 : 0));
    byte[] buffer = new byte[len];
    System.arraycopy(str, 0, buffer, 0, len - (nullTerminateStrings ? 1 : 0));
    if (nullTerminateStrings) {
        buffer[len - 1] = 0;
    }
    characteristic.setValue(buffer);
}

问题核心:Math.min(23, ...) 直接将发送数据截断为最多23字节,没有任何警告或异常。

WriteBytes 走 Integer 路径,无硬编码长度限制。缓冲区大小等于实际数据大小。

三、23字节的来源

项目 说明
BLE 4.0 ATT MTU 默认值 23 字节 规范规定的最小值
ATT 头部开销 3 字节 操作码 + 句柄
实际有效载荷 20 字节 23 - 3 = 20
NullTerminateStrings 开销 1 字节 默认追加
WriteStrings 实际可用 22 字节 23 - 1(null终止符)

为什么23字节不应硬编码:

  1. MTU 是可协商的:BLE 4.2+ 支持协商更大的 MTU(最大512字节)
  2. Android BLE 栈自动处理分片
  3. 硬编码过时了:这个值是 BLE 4.0 的最小 MTU
  4. 正确做法:应使用协商后的 MTU 值

四、WriteStrings 的问题清单

  1. 23字节截断 -- 超过23字节的字符串被静默截断,无警告(严重)
  2. Null终止符默认开启 -- nullTerminateStrings = true,占用1字节,实际可用仅22字节(中等)
  3. 只取 data.get(0) -- 只写第一个字符串,忽略列表中的其他字符串(中等)
  4. 无 MTU 协商感知 -- 不查询当前连接的 MTU 大小(中等)

五、解决方案

方案1(推荐):用 WriteBytes 发送字符串

将字符串转为字节列表后使用 WriteBytes 发送。WriteBytes 走 Integer 路径无23字节限制。

方案2:修改 NullTerminateStrings

在 Designer 中将 NullTerminateStrings 设为 false,确保每次发送的字符串不超过 23 字节。

方案3:修改源码(根本修复)

使用协商后的 MTU 值替代硬编码的 23。

六、总结

对比项 WriteStrings WriteBytes
长度限制 23字节硬编码 无硬编码限制
Null终止符 默认追加 不追加
截断行为 静默截断 不截断
推荐度 短字符串可用 推荐

结论:WriteStrings 的 23 字节硬编码是 BLE 4.0 最小 MTU 的过时简化,不应硬编码。推荐使用 WriteBytes 发送字符串作为 workaround。

参考资料

文档版本:2026.05 | 作者:App Inventor 2 中文网

相关文章
|
5天前
|
人工智能 弹性计算 自然语言处理
2026年阿里云最新活动:云服务器抢购与特惠、云产品免费试用、AI产品活动
2026年,阿里云持续深化普惠战略,围绕云服务器、免费试用与AI产品三大板块推出系列优惠。云服务器方面,轻量应用服务器低至38元/年,ECS经济型e实例99元/年、u1实例199元/年,新购续费同价,活动有效期至2027年3月。免费试用覆盖160+云产品及多款解决方案,新客最高可领12个月试用权益。AI产品方面,阿里云百炼Token Plan提供多模型灵活订阅,按量达标最高返200元优惠券;HappyHorse视频生成模型限时8折;OpenClaw AI助理9.9元/月起即可部署。无论个人开发者还是企业用户,均可借助上述活动实现低成本上云与智能化升级。
|
5天前
|
安全 JavaScript 前端开发
《ZAKU渗透论:卓伊凡的2026渗透工程》第四章:Web攻击原理(下)——XSS、CSRF、文件上传漏洞
本章详解XSS、CSRF与文件上传三大Web漏洞:XSS通过注入恶意脚本窃取Cookie;CSRF伪造已登录用户请求执行非自愿操作;文件上传漏洞则因校验缺失致服务器被控。三者共性——过度信任用户输入。(239字)
291 10
|
2月前
|
人工智能 弹性计算 数据可视化
OpenClaw一键部署保姆级教程,新手小白也能轻松“养龙虾”!
OpenClaw(“龙虾”)是一款开源AI智能体,因红色小龙虾图标得名,部署过程被戏称“养龙虾”。本文提供阿里云一键部署保姆级教程:两步搞定——购买预装镜像服务器+可视化配置API密钥,新手零代码即可拥有专属AI助理!
368 11
|
5天前
|
API
阿里云微服务引擎 MSE 及 API 网关 2026 年 5 月产品动态
阿里云微服务引擎 MSE 及 API 网关 2026 年 5 月产品动态。
162 20
|
5天前
|
人工智能 缓存 弹性计算
阿里云服务器2核4G5M199元解析:独享型u1实例,性能、适用场景、购买和续费规则介绍
阿里云通用算力型u1实例(ecs.u1-c1m2.large)2核4G、5M带宽、80G ESSD Entry云盘,活动特惠价仅199元/年(官网价3498.36元),企业新老用户同享,续费同价至2027年3月31日,每人限购1台。该实例采用独享型架构,搭载Intel至强可扩展处理器,内网带宽1Gbit/s、收发包30万PPS、云盘IOPS 1万,性能稳定,适合企业官网、中小Web应用、轻量数据库及开发测试等场景。
|
2月前
|
人工智能 安全 API
Hermes Agent 部署踩坑无数?阿里云一站式落地教程,全程10分钟
继OpenClaw爆火后,Nous Research推出的Hermes Agent成为开源Agent新顶流:自进化闭环学习、跨会话持久记忆、支持Telegram/WhatsApp/钉钉等15+平台,开箱即用。
620 15
|
5天前
|
SQL JSON 关系型数据库
企业级多模态分析计算引擎选型:阿里云 AnalyticDB MySQL 统一分析平台方案
阿里云AnalyticDB MySQL版是PB级云原生实时数据仓库,首创多模态统一分析引擎,单SQL原生支持SQL分析、向量检索、全文搜索与JSON分析,替代3–5套独立系统,综合成本降50%+,运维复杂度降80%,适用于AI+数据融合、多源异构统一查询等企业级场景。
158 17
企业级多模态分析计算引擎选型:阿里云 AnalyticDB MySQL 统一分析平台方案
|
5天前
|
数据采集 存储 算法
视频 RAG 中分块策略:基于停顿、滑动窗口与基于 LLM 的方法
本文探讨视频RAG中的核心挑战——如何为无时间结构的视频转录文本设计有效分块策略。对比传统文本分块,提出基于停顿、重叠窗口、递归切分及LLM驱动的主题分块四层方案,实现细粒度检索与全局理解兼顾,提升视频内容检索准确性与上下文完整性。
145 13
视频 RAG 中分块策略:基于停顿、滑动窗口与基于 LLM 的方法
|
5天前
|
机器学习/深度学习 数据采集 人工智能
田间杂草检测数据集分享(适用于YOLO系列深度学习分类检测任务)
本数据集含4000张真实农田图像(小麦/玉米/水稻田),YOLO格式标注杂草目标,覆盖多天气、光照与视角,适用于YOLO系列等目标检测模型训练,助力智能除草与精准农业研究。(239字)
247 16
|
5天前
|
监控 API Windows
WGCLOUD v3.6.8 正式更新
WGCLOUD v3.6.8发布:修复CPU/内存等指标偶现为0、大屏离线数据不显示等Bug;新增Windows系统服务列表及开放API;优化告警脚本执行与SNMP设备运行时间兼容性。升级方式详见官方图示。