mirror of
https://github.com/l1ving/youtube-dl
synced 2024-12-22 15:22:51 +08:00
add cookie and referer in headers, change the video url
This commit is contained in:
parent
6c7b26e13f
commit
51094b1b08
@ -6,6 +6,9 @@ import base64
|
|||||||
from .common import InfoExtractor
|
from .common import InfoExtractor
|
||||||
from ..compat import (
|
from ..compat import (
|
||||||
compat_urllib_parse,
|
compat_urllib_parse,
|
||||||
|
compat_cookiejar,
|
||||||
|
compat_cookies,
|
||||||
|
compat_urllib_request,
|
||||||
compat_ord,
|
compat_ord,
|
||||||
)
|
)
|
||||||
from ..utils import (
|
from ..utils import (
|
||||||
@ -188,19 +191,28 @@ class YoukuIE(InfoExtractor):
|
|||||||
video_id = self._match_id(url)
|
video_id = self._match_id(url)
|
||||||
|
|
||||||
def retrieve_data(req_url, note):
|
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')
|
cn_verification_proxy = self._downloader.params.get('cn_verification_proxy')
|
||||||
if cn_verification_proxy:
|
if cn_verification_proxy:
|
||||||
req.add_header('Ytdl-request-proxy', cn_verification_proxy)
|
req.add_header('Ytdl-request-proxy', cn_verification_proxy)
|
||||||
|
|
||||||
raw_data = self._download_json(req, video_id, note=note)
|
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)
|
video_password = self._downloader.params.get('videopassword', None)
|
||||||
|
|
||||||
# request basic data
|
# 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:
|
if video_password:
|
||||||
basic_data_url += '?password=%s' % video_password
|
basic_data_url += '?password=%s' % video_password
|
||||||
|
|
||||||
@ -208,7 +220,8 @@ class YoukuIE(InfoExtractor):
|
|||||||
basic_data_url,
|
basic_data_url,
|
||||||
'Downloading JSON metadata 1')
|
'Downloading JSON metadata 1')
|
||||||
data2 = retrieve_data(
|
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')
|
'Downloading JSON metadata 2')
|
||||||
|
|
||||||
error_code = data1.get('error_code')
|
error_code = data1.get('error_code')
|
||||||
|
Loading…
Reference in New Issue
Block a user