分析QNAP无法将音频串流到小米AI音箱的问题

一、问题:QNAP 4.3.6无法DLNA串流小米AI音箱,Music Station中无法发现网络音频设备。

二、定位:

1. 刷新Music Station

dmc.php → /mnt/ext/opt/musicstation/api/dmc.php → libs/class_mediacontroller.php

发现实际通过 qRPlayerAgent -c ListRender 来获得可串流设备

2. qRPlayerAgent(C++程序)

/usr/local/medialibrary/bin/qRPlayerAgent -c ListRender 

确实无小米AI音箱输出,继续定位:qRPlayerAgent → rpc: qRPlayerCenter → process() → list_render(...),发现此方法实际解析 /usr/bin/qDmcAgent -c list 结果,然后通过 dlna_device_doc_gen() 生成xml。

3. qDmcAgent

执行 /usr/bin/qDmcAgent -c list ,发现有小米AI音箱的DLNA信息。奇怪!

QDMS 430.1.8.4

小米AI音箱-xxxx

uuid:xxx-xxx-xxx-xxx-xxx

xxx.xxx.xxx.xxx

xx:xx:xx:xx:xx:xx

100

4. qRPlayerCenter 的 dlna_device_doc_gen() 方法

发现需要 qDmcAgent 返回type子节点才正常生成xml,而上一步显然没有。

5. qDmcd

qDmcAgent → rpc: qDmcd → getRanderDeviceListXML(),需要通过Sink信息来生成video,audio,photo等,然而没有抓到小米AI音箱的该项信息(也许小米本身就没有提供)导致第3步的xml没有,最终导致该设备无法在 qRPlayerAgent -c ListRender 中输出。

三、解决思路(任一一个方法应该都可以):

1. 小米AI音箱的问题,需要输出Sink告知是audio设备。

2. QNAP对小米AI音箱做特殊处理(其实可以看到,QNAP已对 Sonos 做了特殊处理)。

3. 用个bash替换,手动给 qDmcAgent -c list 返回的里加上audio

四、尝试解决

前面两个都得等厂家,先试了3,已经在网络媒体播放器里出现了。

小米AI音箱添加到QNAP网络媒体播放器

但无法正确播放,似乎 qRPlayerAgent 通过DLNA协议串流小米AI音箱总是有问题(-4错误意味着“Renderer not found”,而 qDmcAgent 又没有问题(说明DLNA协议是ok的):

# ./qRPlayerAgent -c GetVolume --dev uuid:xxx-xxx-xxx-xxx-xxx

QDMS 430.1.8.4

-4

# ./qDmcAgent -c getVolume --uuid uuid:xxx-xxx-xxx-xxx-xxx

QDMS 430.1.8.4

20

五、曲线解决

试试Airplay?通过AirConnect将DLNA协议包装为Airplay,但是QNAP不认,qRPlayerCenter中获取Airplay的设备,必须是 _airplay._tcp :

/usr/sbin/avahi-browse -rkpt _airplay._tcp

而AirConnect包装后只有音频,协议是 _raop._tcp

# ./avahi-browse -a

+  eth0 IPv4 xxxxxx@______AI______-xxxx+            _raop._tcp          local

吐了

你可能感兴趣的:(分析QNAP无法将音频串流到小米AI音箱的问题)