diff options
| author | Celthi <txtlu0@gmail.com> | 2015-12-10 21:42:12 +0800 | 
|---|---|---|
| committer | Celthi <txtlu0@gmail.com> | 2015-12-10 21:42:12 +0800 | 
| commit | 51094b1b0885462c19cc2c75f545e621f8a3aa0a (patch) | |
| tree | 855e26602914ccd32ffc6eb3efcc484d643490a6 | |
| parent | 6c7b26e13f1aebe7bd19a7899b01e49b052febe5 (diff) | |
add cookie and referer in headers, change the video url
| -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') | 
