I have the next HLS playlist: https://digitacdn.akamaized.net/hls/live/629243/radiosuomipop/master-128000.m3u8. It contains AAC audio file segments links. File content is:
#EXTM3U
#EXT-X-VERSION:3
## Created with Z/IPStream R/2 v1.03.23
#EXT-X-MEDIA-SEQUENCE:2984548
#EXT-X-TARGETDURATION:6
#EXT-X-PROGRAM-DATE-TIME:2018-10-23T11:44:44Z
#EXTINF:5.99, no desc
01493/seg128000-02984548.aac
#EXTINF:5.99, no desc
01493/seg128000-02984549.aac
#EXTINF:5.99, no desc
01493/seg128000-02984550.aac
#EXTINF:5.99, no desc
01493/seg128000-02984551.aac
#EXTINF:5.99, no desc
01493/seg128000-02984552.aac
#EXTINF:5.99, no desc
01493/seg128000-02984553.aac
I can not understand where these segments are located. Could anybody explain me that? How can I reach each separate segment to play it, for instance, with NAudio MediaFoundationReader?
Due to the lack of leading
/
, the resources exist at a location relative to the source document in exactly the same way as links in HTML pages work. So: for instance01593/seg128000-03184874.aac
found in the document athttps://digitacdn.akamaized.net/hls/live/629243/radiosuomipop/master-128000.m3u8
exists athttps://digitacdn.akamaized.net/hls/live/629243/radiosuomipop/01593/seg128000-03184874.aac
.A safe way of dealing with this is to use existing overloads on the
Uri
class:Done this way, the resulting Urls will be assembled using the same logic as used by browsers, correctly dealing with relative (
32724/foo
), local absolute (/32724/foo
) and fully qualified URLs (http://somehost/32724/foo
).