「Suiteki」- 小米手环密钥获取工具的实现原理

本文介绍了一种从小米运动健康及小米穿戴应用的日志文件中提取设备密钥的方法,并分享了一个用于提取这些密钥的Java库。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

该文章在Sky233’s Blog同步发布,戳我直达

前言

开始做这个项目已经很久了,一开始只是想方便自己使用,但后来还是选择开发这个软件来给大众使用,方便他们获取这个密钥。这也是我做的第一个项目,下面就来讲一下我是怎么开发这个软件,和这个软件的原理


原理

针对小米运动健康和小米穿戴来讲,他们获取的密钥就是通过它们生成的日志文件来读取密钥
下面的是小米运动健康的一个日志文件的片段,这个日志文件存放在**/storage/emulated/0/Android/data/com.mi.health/files/log/XiaomiFit.device.log**中

2022-12-24 19:39:52.402|3.11.1|I|DeviceModel_7803_7803|the size of devices is 1 after there eco was filter
2022-12-24 19:39:52.402|3.11.1|I|DeviceModel_7803_7803|requestBindDeviceList bindDevices is [Device(did='huami.32098/11743619', productId=0, model='hmpace.motion.v6nfc', name='小米手环6 NFC版   ', extraValues=null, identifier='huami.32098/11743619', alias='', status=1, detail=Detail(mac=E3:A5:65:78:95:38, sn=32098/11743619, token=null, encryptKey=null, irqKey=null, beaconKey=null, thirdNodeId=null, peripheralId=null, authKey=51e59f734548bb0c759cb030d5893586, macAddress=E3:A5:65:78:95:38, deviceId=E3A565FFFE789538, phoneId=null, randomMac=null), isOwner=true)]
2022-12-24 19:39:52.409|3.11.1|I|XiaomiFit_7803_7803|com.mi.health:device receive lifecycle event, put
2022-12-24 19:39:52.409|3.11.1|I|AppManager_7803_7803|onLifecycleReceive() called with: activity = com.xiaomi.fitness.device.manager.ui.guide.GuideOpenKeepAliveSettingActivity;112235250;23004, lifecycle = onCreated
2022-12-24 19:39:52.425|3.11.1|I|XiaomiFit_7803_7803|com.mi.health:device receive lifecycle event, put
2022-12-24 19:39:52.425|3.11.1|I|AppManager_7803_7803|onLifecycleReceive() called with: activity = com.xiaomi.fitness.device.manager.ui.guide.GuideOpenKeepAliveSettingActivity;112235250;23004, lifecycle = onPostCreated
2022-12-24 19:39:52.436|3.11.1|I|XiaomiFit_7803_7803|com.mi.health:device receive lifecycle event, put
2022-12-24 19:39:52.436|3.11.1|I|AppManager_7803_7803|onLifecycleReceive() called with: activity = com.xiaomi.fitness.device.manager.ui.guide.GuideOpenKeepAliveSettingActivity;112235250;23004, lifecycle = onStart
2022-12-24 19:39:52.448|3.11.1|I|XiaomiFit_7803_7803|com.mi.health:device receive lifecycle event, put
2022-12-24 19:39:52.448|3.11.1|I|AppManager_7803_7803|onLifecycleReceive() called with: activity = com.xiaomi.fitness.device.manager.ui.guide.GuideOpenKeepAliveSettingActivity;112235250;23004, lifecycle = onResume
2022-12-24 19:39:52.672|3.11.1|I|DeviceModel_7803_7803|getEcoDevices scaleData is "{\"code\":0,\"message\":\"\",\"result\":{\"list\":[]}}"
2022-12-24 19:39:52.715|3.11.1|I|DeviceModel_7803_7803|getEcoDevices shareList is "{\"code\":200,\"message\":\"\",\"data\":[]}"
2022-12-24 19:39:52.715|3.11.1|I|DeviceModel_7803_7803|requestBindDeviceList ecoBindDevices is []

我们可以看到日志文件中包含了小米手环密钥,设备地址(MAC),设备型号(Model)
我们就可以分析这些日志文件来获取到我们想要的内容, 小米穿戴同理, 但小米穿戴则没有前者的内容丰富
仅有密钥和设备地址罢了, 但也勉强够用, 而小米穿戴的日志文件则是**/storage/emulated/0/Android/data/com.xiaomi.wearable/files/log/Wearable.log**


但很显然这样不够, 因为我们没有考虑到ZeppLife(原小米运动健康)的用户, 而ZeppLife是没有日志文件可以分析, 这样我们就需要参考Github上面的一个项目huami-token , 这个项目是用Python编写的, 没法在手机上直接运行, 所以我把它改写成了Java, 需要的话可以看我这个项目Suiteki-Lib, 原理是一样的, 需要的话可以去看一下那个Python项目

收尾

主要这篇文章就是试试水,也不打算写什么有用的东西,就想记录一下,这篇文章很水就是了

在ARM架构上遇到"ImportError: libpython3.7m.so.1.0"的错误,通常是因为缺少或者无法找到对应的Python库文件。该错误的解决方法如下: 1. 检查Python库文件路径:首先,确保你的系统中已经正确安装了Python3.7版本,并且库文件"libpython3.7m.so.1.0"位于正确的库文件路径下。可以通过以下命令查看库文件路径:`ldconfig -p | grep libpython3.7m.so.1.0`。如果未找到该文件,那么可能是因为Python3.7版本缺失或者安装路径不正确。 2. 更新LD_LIBRARY_PATH:如果库文件路径不正确,可以尝试更新系统的LD_LIBRARY_PATH环境变量,将正确的库文件路径添加到其中。可以使用以下命令进行修改:`export LD_LIBRARY_PATH=/path/to/python3.7/libs:$LD_LIBRARY_PATH`。其中,"/path/to/python3.7/libs"是Python3.7库文件的路径。 3. 检查依赖库:除了检查Python库文件,还需要确保该错误不是由于其他依赖库缺失所致。使用`ldd /path/to/your/arm/bin`命令来检查可执行文件所依赖的库文件,确保所有的依赖库都存在且路径正确。 4. 重新编译或安装:如果上述方法仍无法解决问题,可以尝试重新编译或安装相关软件或库。特别是在使用交叉编译时,需要确保交叉编译环境正确配置。 总之,"ImportError: libpython3.7m.so.1.0"错误通常是由于ARM架构下的Python库文件缺失或路径不正确所导致的。根据具体情况,可以通过检查库文件路径、更新LD_LIBRARY_PATH、检查依赖库以及重新编译或安装软件来解决该问题。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值