From 50b6909db689277295b3938b7729070f54fb02d3 Mon Sep 17 00:00:00 2001 From: arichi Date: Wed, 7 Dec 2016 00:09:05 +0800 Subject: [PATCH] use _download_json to get play_url --- youtube_dl/extractor/pandoratv.py | 12 ++++++++---- 1 file changed, 8 insertions(+), 4 deletions(-) diff --git a/youtube_dl/extractor/pandoratv.py b/youtube_dl/extractor/pandoratv.py index a449811e6..3e37ae01d 100644 --- a/youtube_dl/extractor/pandoratv.py +++ b/youtube_dl/extractor/pandoratv.py @@ -12,6 +12,7 @@ from ..utils import ( float_or_none, parse_duration, str_to_int, + urlencode_postdata, ) @@ -58,10 +59,13 @@ class PandoraTVIE(InfoExtractor): if not height: continue - post_data = ('prgid=%s&runtime=%s&vod_url=%s' % (video_id, info.get('runtime'), format_url)).encode() - data = compat_urllib_request.urlopen("http://m.pandora.tv/?c=api&m=play_url", data=post_data).read() - encoding = self._guess_encoding_from_content('json', data) - play_url = self._parse_json(data.decode(encoding, errors='ignore'), video_id) + post_data = {'prgid': video_id, 'runtime': info.get('runtime'), 'vod_url': format_url} + play_url = self._download_json('http://m.pandora.tv/?c=api&m=play_url', video_id, + data=urlencode_postdata(post_data), + headers={ + 'Origin': url, + 'Content-Type': 'application/x-www-form-urlencoded' + }) format_url = play_url.get('url') if not format_url: continue