Sonos Music API实现“首次请求时无法浏览音乐”错误

时间:2016-12-12 10:47:19

标签: sonos

在我们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&amp;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&amp;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&amp;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>

1 个答案:

答案 0 :(得分:0)

显然这是在响应中存在mediaCollection时引起的。经过大量的调试和尝试,我发现它只是通过从响应中删除它来解决。