|
@ -1,15 +1,11 @@ |
|
|
# coding: utf-8 |
|
|
# coding: utf-8 |
|
|
from __future__ import unicode_literals |
|
|
from __future__ import unicode_literals |
|
|
|
|
|
|
|
|
import json |
|
|
|
|
|
import base64 |
|
|
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 ( |
|
@ -89,7 +85,7 @@ class YoukuIE(InfoExtractor): |
|
|
).decode('ascii').split('_') |
|
|
).decode('ascii').split('_') |
|
|
|
|
|
|
|
|
# get oip |
|
|
# get oip |
|
|
oip = data2['security']['ip'] |
|
|
|
|
|
|
|
|
oip = data1['security']['ip'] |
|
|
|
|
|
|
|
|
# get fileid |
|
|
# get fileid |
|
|
string_ls = list( |
|
|
string_ls = list( |
|
@ -136,7 +132,8 @@ class YoukuIE(InfoExtractor): |
|
|
format = stream.get('stream_type') |
|
|
format = stream.get('stream_type') |
|
|
video_urls = [] |
|
|
video_urls = [] |
|
|
for dt in stream['segs']: |
|
|
for dt in stream['segs']: |
|
|
n = str(int(dt['size'])) |
|
|
|
|
|
|
|
|
#n = str(int(dt['size'])) |
|
|
|
|
|
n = str(stream['segs'].index(dt)) |
|
|
param = { |
|
|
param = { |
|
|
'K': dt['key'], |
|
|
'K': dt['key'], |
|
|
'hd': self.get_hd(format), |
|
|
'hd': self.get_hd(format), |
|
@ -177,6 +174,8 @@ class YoukuIE(InfoExtractor): |
|
|
ext_dict = { |
|
|
ext_dict = { |
|
|
'flv': 'flv', |
|
|
'flv': 'flv', |
|
|
'mp4': 'mp4', |
|
|
'mp4': 'mp4', |
|
|
|
|
|
'mp4hd': 'mp4', |
|
|
|
|
|
'mp4hd2': 'mp4', |
|
|
'hd2': 'flv', |
|
|
'hd2': 'flv', |
|
|
'hd3': 'flv', |
|
|
'hd3': 'flv', |
|
|
'3gp': 'flv', |
|
|
'3gp': 'flv', |
|
@ -214,7 +213,6 @@ class YoukuIE(InfoExtractor): |
|
|
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) |
|
|
jsonDumpIn = json.dumps(raw_data,indent = 1) |
|
|
|
|
|
|
|
|
|
|
|
return raw_data['data'] |
|
|
return raw_data['data'] |
|
|
|
|
|
|
|
@ -260,7 +258,7 @@ class YoukuIE(InfoExtractor): |
|
|
'formats': [], |
|
|
'formats': [], |
|
|
# some formats are not available for all parts, we have to detect |
|
|
# some formats are not available for all parts, we have to detect |
|
|
# which one has all |
|
|
# which one has all |
|
|
} for i in range(max(len(v) for v in data1['stream']))] |
|
|
|
|
|
|
|
|
} for i in range(max(len(v.get('segs')) for v in data1['stream']))] |
|
|
for stream in data1['stream']: |
|
|
for stream in data1['stream']: |
|
|
fm = stream.get('stream_type') |
|
|
fm = stream.get('stream_type') |
|
|
video_urls = video_urls_dict[fm] |
|
|
video_urls = video_urls_dict[fm] |
|
|