【米家】使用小爱音箱随机播放 SMB 共享中存储的音乐文件

本文介绍了一种解决方案,通过将SMB共享转换为HTTP并使用Node.js库来让小爱音箱播放存储在小米路由器共享硬盘中的音乐。涉及的技术包括Node.js的使用、M3U8歌单生成和对小爱音箱语音指令的监听。

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

一、问题背景

        我想让小爱音箱播放存储在小米路由器共享硬盘(使用 SMB 协议访问)中的音乐文件,但是它就不,那只能自己动手了。

二、解决方案

经过研究,需要解决以下问题:

1. 将 SMB 共享转为 HTTP 协议,因为小爱音箱不支持 SMB 协议。

2. 生成随机的 M3U8 歌单,否则小爱音箱一次只会播放一首。

3. 监听小爱的对话,否则无法得知何时开始。

你至少需要准备以下设备:

1. 一台可以运行 Node.js 最新 LTS 版本的任意设备。

2. 小爱音箱必须能访问到你的设备。

3. 设备必须能访问 SMB 共享。

三、解决方法

1. 安装 Node.js ,请安装最新的 LTS 版本,其余版本未经过测试。

2. 使用 npm 安装全局库 @greatnxy/mi-smb 和 @greatnxy/mi-hello 。

npm i -g @greatnxy/mi-smb @greatnxy/mi-hello

@greatnxy/mi-smb 为本人开发。但是其依赖项 @greatnxy/smb 最初为 bchelli 的 node-smb2 并由 fridjon 增加流传输支持(于 Pull Request 中未被合并),我只重写了 createreadstream.js ,修改后的仓库未上传。

@greatnxy/mi-hello 参考了 MIGPT 的代码结构,并做了优化。其依赖项 @greatnxy/mi-service 为使用 GPT-4 翻译的 MIService 库,本人只做了少许修改。

 3. 启动 SMB 监听服务器。

mi-smb "LOC_PORT={{服务器端口}};SMB_SVR='{{SMB地址}}';SMB_SHARE='{{共享路径}}'"

服务器端口:任意可用端口均可。如果你不知道这是什么,就填 3000 。

SMB地址:访问 SMB 共享的地址。如果你使用 Windows ,在文件资源管理器中可以直接在地址栏输入“\\{{SMB地址}}”访问。

共享路径:指向音乐文件所在文件夹的位置。如果你使用 Windows ,在文件资源管理器中可以直接在地址栏输入“\\{{SMB地址}}\{{共享路径}}”访问该文件夹。

示例:

mi-smb "LOC_PORT=3000;SMB_SVR='192.168.3.1';SMB_SHARE='音乐'"

4. 启动小爱音箱监听服务。

mi-hello "MI_USER='{{小米账号}}';MI_PASS='{{小米账号的密码}}';MI_DID='{{设备DID}}';MI_HW='{{设备型号}}';MI_LSVR='{{服务器地址}}'"

小米账号:你的小米账号。请务必确保已经在监听服务设备所在地登录过,否则登录可能会被拒绝。

小米账号的密码:你的小米账号的密码。

设备DID:选填,设备的 DID 。如果你不知道,请移除此参数。

设备型号:选填,设备的型号。如果你不知道,请移除此参数。

服务器地址:能被小爱音箱访问的服务器地址,需要包含上一步输入的端口号。不能是 localhost ,那样小爱音箱只会不停访问自己。

示例(完整):

mi-hello "MI_USER='11451419198';MI_PASS='11451419198';MI_DID='11451419-1981-0114-5141-919810114514';MI_HW='LX00';MI_LSVR='192.168.31.114:3000'"

示例(省略设备信息):

mi-hello "MI_USER='11451419198';MI_PASS='11451419198';MI_LSVR='192.168.31.114:3000'"

如果省略了设备信息参数,启动时你会被要求选择一个希望监听的设备。

四、使用方法

1. 播放本地音乐。以下对话示例可以让小爱音箱播放音乐:

  • 播放本地音乐
  • 听本地的歌
  • 放本地歌单
  • 播本地的 MP3

使用以下正则表达式匹配:

/^(播放|播|放|听)本地的?(音乐|歌([曲单])?|文件|[mn]p3)$/i

2. 停止播放。以下对话示例可以让小爱音箱在播放本地音乐的状态下停止播放:

  • 闭嘴
  • 住口
  • 别放了
  • 停停停
  • 拜拜

使用以下正则表达式匹配:

/^((暂停|停止?|别)([唱放播]|播放)?(音乐|歌曲?)?了?|[闭住][口嘴]|再见|拜|退下)+$/i

3. 播放下一首本地音乐。以下对话示例可以让小爱音箱在播放本地音乐的状态下切歌:

  • 下一首
  • 切歌
  • 换歌
  • 播下一首

使用以下正则表达式匹配:

/^(([放播换]?[上下]|换)一?[首曲]|[切换]歌)$/i

五、注意事项 

1. 由于小爱音箱的奇葩设计,任何打断操作都会导致歌曲播放中止并丢失进度。因此任何情况的打断都会重新随机播放。

2. 如果你想停止播放本地音乐,必须显式地命令其停止播放,否则监听服务检测到播放“意外”中断会不断尝试恢复播放。

3. 歌曲格式必须相同,且不能只修改后缀名。如果音乐文件夹内有不同格式的歌曲(如 mp3 和 flac 格式),小爱音箱可能会在格式变化时卡住。

4. 文件夹内只能有音乐文件,如果有其它文件或文件夹也会被当做音乐播放。

### ESP8266与米家小爱同学的集成方法及兼容性 ESP8266作为一种低成本、高效率的Wi-Fi模块,在物联网设备开发中被广泛应用。其支持多种协议和框架,能够轻松实现与其他智能家居生态系统的集成。以下是关于ESP8266与小米生态系统(包括米家App和小爱同学)的集成方法及其兼容性的详细介绍。 #### 一、ESP8266与米家App的集成 为了使基于ESP8266的设备可以接入米家App,通常需要通过Mi Home SDK或者第三方中间件来完成连接配置。具体过程如下: 1. **使用MiOT开发者平台注册产品并获取认证** 开发者需先登录小米IoT开发者平台,创建一个新的硬件项目,并按照指引提交必要的资料以获得审核批准[^1]。一旦成功注册,即可下载对应的固件文件用于后续烧录操作。 2. **OTA升级至官方指定固件版本** 完成上述步骤之后,将目标板载入由小米提供的特定固件镜像,该镜像包含了适配于米家应用的功能逻辑以及安全机制。此阶段可能涉及多次迭代测试直至满足所有功能需求为止。 3. **编写自定义业务代码并与云端交互** 基础网络层初始化完成后,还需针对实际应用场景设计个性化的控制指令集,这些命令最终会被上传到服务器端供手机客户端调用显示状态更新或执行动作反馈等服务[^2]。 ```c #include <Arduino.h> #include <WiFiClientSecure.h> void setup() { Serial.begin(9600); } void loop() { WiFiClient client; if (!client.connect("api.miot-spec.com", 443)) { return; } String postStr = "{\"id\": \"light\", \"value\": true}"; client.print(String("POST /v2/action HTTP/1.1\r\n") + "Host: api.miot-spec.com\r\n" + "Content-Type: application/json;charset=utf-8\r\n" + "Content-Length: " + postStr.length() + "\r\n\r\n" + postStr); while (client.connected()) { String line = client.readStringUntil('\n'); if (line == "\r") break; } } ``` 以上是一个简单的示例程序片段,展示了如何向小米开放API发送HTTP请求模拟开关灯泡的操作。 --- #### 二、ESP8266与小爱同学的语音控制对接 为了让用户的语音输入可以通过小爱音箱触发相应的家庭自动化响应,则除了基本联网能力外还需要额外考虑以下几个方面的工作流程: 1. **绑定关系建立** 用户首次启动时应引导他们完成账户关联手续,即允许授权访问个人数据以便同步偏好设置信息给本地网关节点处理。 2. **解析意图模型训练样本准备** 提前准备好一系列标准句型作为机器学习算法素材库的一部分,从而提高识别精度减少误判率。 3. **事件驱动架构下的消息分发策略制定** 当检测到来自信号源的有效音频流后迅速分析其中蕴含的意义并将结果转发至相应的目标实体上进一步处置。 值得注意的是,由于目前市面上主流的小爱系列终端并不直接暴露对外RESTful接口资源位置地址列表出来让用户自行抓取利用;因此更多时候我们倾向于借助某些成熟的中介解决方案比如NodeRED图形化编程工具链配合IFTTT之类的服务提供商间接达成目的效果更好一些[^3]。 --- ### 总结 综上所述可以看出尽管存在一定的技术门槛障碍但仍可通过合理规划逐步克服困难顺利实现预期目标成果展示。对于初学者而言建议优先参考现成案例文档积累实践经验后再尝试独立探索未知领域拓展视野范围。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

GreatNXY

阿巴阿巴阿巴阿巴

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值