diff options
Diffstat (limited to 'youtube_dl')
-rw-r--r-- | youtube_dl/extractor/youku.py | 21 |
1 files changed, 17 insertions, 4 deletions
diff --git a/youtube_dl/extractor/youku.py b/youtube_dl/extractor/youku.py index 69ecc837a..d077e03db 100644 --- a/youtube_dl/extractor/youku.py +++ b/youtube_dl/extractor/youku.py @@ -6,6 +6,9 @@ import base64 from .common import InfoExtractor from ..compat import ( compat_urllib_parse, + compat_cookiejar, + compat_cookies, + compat_urllib_request, compat_ord, ) from ..utils import ( @@ -188,19 +191,28 @@ class YoukuIE(InfoExtractor): video_id = self._match_id(url) def retrieve_data(req_url, note): - req = sanitized_Request(req_url) + + + headers = { + 'Referer': req_url, + } + self._set_cookie('youku.com','xreferrer','http://www.youku.com') + req = sanitized_Request(req_url,headers=headers) cn_verification_proxy = self._downloader.params.get('cn_verification_proxy') if cn_verification_proxy: req.add_header('Ytdl-request-proxy', cn_verification_proxy) raw_data = self._download_json(req, video_id, note=note) - return raw_data['data'][0] + + return raw_data['data']['security'] + video_password = self._downloader.params.get('videopassword', None) # request basic data - basic_data_url = 'http://v.youku.com/player/getPlayList/VideoIDS/%s' % video_id + #basic_data_url = 'http://v.youku.com/player/getPlayList/VideoIDS/%s' % video_id + basic_data_url = "http://play.youku.com/play/get.json?vid=%s&ct=12" % video_id if video_password: basic_data_url += '?password=%s' % video_password @@ -208,7 +220,8 @@ class YoukuIE(InfoExtractor): basic_data_url, 'Downloading JSON metadata 1') data2 = retrieve_data( - 'http://v.youku.com/player/getPlayList/VideoIDS/%s/Pf/4/ctype/12/ev/1' % video_id, + #'http://v.youku.com/player/getPlayList/VideoIDS/%s/Pf/4/ctype/12/ev/1' % video_id, + "http://play.youku.com/play/get.json?vid=%s&ct=12" % video_id, 'Downloading JSON metadata 2') error_code = data1.get('error_code') |