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 中文网

相关文章
|
3天前
|
人工智能 弹性计算 自然语言处理
2026年阿里云最新活动:云服务器抢购与特惠、云产品免费试用、AI产品活动
2026年,阿里云持续深化普惠战略,围绕云服务器、免费试用与AI产品三大板块推出系列优惠。云服务器方面,轻量应用服务器低至38元/年,ECS经济型e实例99元/年、u1实例199元/年,新购续费同价,活动有效期至2027年3月。免费试用覆盖160+云产品及多款解决方案,新客最高可领12个月试用权益。AI产品方面,阿里云百炼Token Plan提供多模型灵活订阅,按量达标最高返200元优惠券;HappyHorse视频生成模型限时8折;OpenClaw AI助理9.9元/月起即可部署。无论个人开发者还是企业用户,均可借助上述活动实现低成本上云与智能化升级。
|
6天前
|
人工智能 Linux API
阿里云/本地MacOS/Linux/Windows11秒级部署 OpenClaw 图文教程及常见问题解答
OpenClaw(原Clawdbot)凭借轻量化架构、秒级部署能力与强大的大模型集成生态,成为搭建专属AI助手的首选工具。阿里云依托计算巢与轻量应用服务器,为OpenClaw提供官方专属部署模板,实现真正意义上的秒级部署,全程无需手动配置环境、无需处理复杂依赖,搭配阿里云千问Qwen3-Max大模型,可快速构建具备深度理解、长文本生成、复杂逻辑推理能力的AI机器人,满足个人与企业的智能交互、任务自动化需求。
177 7
|
2天前
|
JSON 自然语言处理 安全
App Inventor 2 如何拼接 JSON 文本?用字典积木轻松搞定
App Inventor 2 中拼接 JSON 文本的最简方法是利用字典积木,字典天生就是 JSON 的表现形式,自动输出标准格式,无需手动拼接字符串。
31 4
|
1月前
|
人工智能 弹性计算 数据可视化
OpenClaw一键部署保姆级教程,新手小白也能轻松“养龙虾”!
OpenClaw(“龙虾”)是一款开源AI智能体,因红色小龙虾图标得名,部署过程被戏称“养龙虾”。本文提供阿里云一键部署保姆级教程:两步搞定——购买预装镜像服务器+可视化配置API密钥,新手零代码即可拥有专属AI助理!
280 11
|
10天前
|
存储 缓存 安全
大模型应用:大模型响应缓存技术完全指南:TTL 缓存装饰器的设计与落地.112
本文详解大模型应用中缓存装饰器的实战实现,直击响应慢、成本高两大痛点。从基础缓存出发,逐步升级为支持TTL过期、线程安全、LRU淘汰、异常防护及哈希键优化的生产级方案,显著提升响应速度、降低Token消耗、增强系统稳定性。
137 7
|
1月前
|
机器学习/深度学习 监控 安全
高校针对性钓鱼攻击机理与防御体系研究 —— 以哈佛大学网络安全事件为例
本文以2026年哈佛大学定向钓鱼攻击事件为样本,剖析高校精准钓鱼的技术特征(域名仿冒、信任滥用、场景定制)与社会工程逻辑,提出融合URL实时检测、SPF/DKIM/DMARC协议加固、MFA认证强化及应急闭环的多层防御体系,并提供可部署的Python检测代码,助力高校构建技术-制度-人员协同的主动防护能力。(239字)
234 11
|
4天前
|
传感器 数据采集 安全
App Inventor 2 向心力实验App - 探究向心力F与角速度ω、半径r、质量m的关系
高中物理新课标要求学生通过实验探究向心力F=m·r·ω²,但现有实验器材操作不便、精度低。本文介绍如何使用App Inventor 2开发向心力实验App,利用手机内置加速度计和陀螺仪传感器,实现低成本、高精度的向心力探究实验,支持F-ω、F-r、F-m三组关系探究及理论曲线对比。
61 4
|
1月前
|
人工智能 安全 API
Hermes Agent 部署踩坑无数?阿里云一站式落地教程,全程10分钟
继OpenClaw爆火后,Nous Research推出的Hermes Agent成为开源Agent新顶流:自进化闭环学习、跨会话持久记忆、支持Telegram/WhatsApp/钉钉等15+平台,开箱即用。
508 15
|
1月前
|
人工智能 缓存 数据中心
大模型应用:大模型多线程推理:并发请求的处理与资源隔离实践.77
本文详解大模型多线程推理与资源隔离技术:通过共享模型、隔离缓存、限制线程数/生成长度/超时时间,实现高并发、低延迟、稳服务。单线程串行耗时85.7秒,多线程(3线程)降至66.5秒,显著提升吞吐量与资源利用率,是大模型规模化落地的核心工程实践。
393 7
|
22天前
|
人工智能 监控 安全
多模态AI(图像+文本)该怎么测试?不是把图片丢给模型这么简单
本文系统阐述多模态AI测试新范式:突破传统文本测试局限,聚焦图像理解、图文对齐、跨模态推理、幻觉防控、安全注入与鲁棒性验证六大核心维度,提出分层模型、六维测试矩阵及自动化评测体系,强调“证据链”验证——答案必须可追溯至图片真实信息。

热门文章

最新文章