add cookie and referer in headers, change the video url
This commit is contained in:
		@@ -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')
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user