在我们Sonos Music API的实现中,遇到了请求相册容器的问题。第一次请求相册时,它总是会失败并显示消息"无法浏览音乐"。如果您再按,然后再次打开相同的相册,它会打开正常,并显示曲目列表和专辑详细信息。
我确实检查了第一个和第二个请求之间服务器的响应是否有任何差异,但没有区别。也没有任何时间差异(请求加载(两次)在我的开发者工作站不到200ms)。
我还使用SoapUI来验证Soap服务器是否返回了正确的数据,并且验证没有任何错误。
测试套件也不会返回任何错误或警告。
有没有办法看到实际的错误?或者有关如何处理此问题的任何建议?
典型的请求如下:
<s:Envelope xmlns:s="http://schemas.xmlsoap.org/soap/envelope/">
<s:Header>
<credentials xmlns="http://www.sonos.com/Services/1.1">
<sessionId>f42257a8-c046-11e6-82d0-d4bed9ed478a</sessionId>
<deviceId>xx-xx-00-00-00-00:x</deviceId>
<deviceProvider>Sonos</deviceProvider>
</credentials>
</s:Header>
<s:Body>
<getMetadata xmlns="http://www.sonos.com/Services/1.1">
<id>album:112779295</id>
<index>0</index>
<count>30</count>
</getMetadata>
</s:Body>
</s:Envelope>
并回复:
<SOAP-ENV:Envelope xmlns:SOAP-ENV="http://schemas.xmlsoap.org/soap/envelope/" xmlns:ns1="http://www.sonos.com/Services/1.1">
<SOAP-ENV:Body>
<ns1:getMetadataResponse>
<ns1:getMetadataResult>
<ns1:index>0</ns1:index>
<ns1:count>13</ns1:count>
<ns1:total>13</ns1:total>
<ns1:mediaCollection>
<ns1:id>album:112779295</ns1:id>
<ns1:itemType>album</ns1:itemType>
<ns1:displayType>list</ns1:displayType>
<ns1:title>Kenny B - Kenny B</ns1:title>
<ns1:summary>blop</ns1:summary>
<ns1:isFavorite>true</ns1:isFavorite>
<ns1:language>NL</ns1:language>
<ns1:country>NL</ns1:country>
<ns1:genreId>genre:1</ns1:genreId>
<ns1:genre>Nederlands</ns1:genre>
<ns1:twitterId/>
<ns1:liveNow>false</ns1:liveNow>
<ns1:onDemand>true</ns1:onDemand>
<ns1:artist>Kenny B</ns1:artist>
<ns1:artistId>artist:1425214</ns1:artistId>
<ns1:canScroll>true</ns1:canScroll>
<ns1:canPlay>true</ns1:canPlay>
<ns1:canEnumerate>true</ns1:canEnumerate>
<ns1:canAddToFavorites>true</ns1:canAddToFavorites>
<ns1:containsFavorite>false</ns1:containsFavorite>
<ns1:canCache>false</ns1:canCache>
<ns1:canSkip>false</ns1:canSkip>
<ns1:albumArtURI>https://mobile.unplug.de/artwork.php?id=112779295&w=300</ns1:albumArtURI>
<ns1:authRequired>false</ns1:authRequired>
<ns1:homogeneous>false</ns1:homogeneous>
<ns1:canAddToFavorite>true</ns1:canAddToFavorite>
</ns1:mediaCollection>
<ns1:mediaMetadata>
<ns1:id>track:610294458</ns1:id>
<ns1:itemType>track</ns1:itemType>
<ns1:displayType>List</ns1:displayType>
<ns1:title>Alleen Jij</ns1:title>
<ns1:mimeType>application/x-mpegURL</ns1:mimeType>
<ns1:trackMetadata>
<ns1:artistId>artist:1425214</ns1:artistId>
<ns1:artist>Kenny B</ns1:artist>
<ns1:albumId>album:112779295</ns1:albumId>
<ns1:albumArtistId>artist:1425214</ns1:albumArtistId>
<ns1:duration>223</ns1:duration>
<ns1:rating>1</ns1:rating>
<ns1:albumArtURI>https://mobile.unplug.de/artwork.php?id=112779295&w=300</ns1:albumArtURI>
<ns1:trackNumber>1</ns1:trackNumber>
<ns1:canPlay>true</ns1:canPlay>
<ns1:canSkip>true</ns1:canSkip>
<ns1:canAddToFavorites>true</ns1:canAddToFavorites>
</ns1:trackMetadata>
</ns1:mediaMetadata>
<ns1:mediaMetadata>
<ns1:id>track:610294459</ns1:id>
<ns1:itemType>track</ns1:itemType>
<ns1:displayType>List</ns1:displayType>
<ns1:title>Als Je Gaat</ns1:title>
<ns1:mimeType>application/x-mpegURL</ns1:mimeType>
<ns1:trackMetadata>
<ns1:artistId>artist:1425214</ns1:artistId>
<ns1:artist>Kenny B</ns1:artist>
<ns1:albumId>album:112779295</ns1:albumId>
<ns1:albumArtistId>artist:1425214</ns1:albumArtistId>
<ns1:duration>191</ns1:duration>
<ns1:rating>1</ns1:rating>
<ns1:albumArtURI>https://mobile.unplug.de/artwork.php?id=112779295&w=300</ns1:albumArtURI>
<ns1:trackNumber>2</ns1:trackNumber>
<ns1:canPlay>true</ns1:canPlay>
<ns1:canSkip>true</ns1:canSkip>
<ns1:canAddToFavorites>true</ns1:canAddToFavorites>
</ns1:trackMetadata>
</ns1:mediaMetadata>
...
</ns1:getMetadataResult>
</ns1:getMetadataResponse>
</SOAP-ENV:Body>
</SOAP-ENV:Envelope>
答案 0 :(得分:0)
显然这是在响应中存在mediaCollection时引起的。经过大量的调试和尝试,我发现它只是通过从响应中删除它来解决。