Instagram 网页版视频是如何限制在 devtools 中找到视频链接进行直接下载的?

2022-05-11 15:58:53 +08:00
 FaiChou

今天想下载 IG 的一个视频, 于是打开了网页端, 找到视频标签, 查看是 blob, 于是去 Network 里找 m3u8, 但是没有找到.

测试链接: https://www.instagram.com/reel/CdYOo_QIB5L/

video 标签:

<video class="tWeCl" crossorigin="anonymous" playsinline="" poster="https://scontent-hkt1-2.cdninstagram.com/v/t51.2885-15/280525371_399280442062025_5345542004741217395_n.jpg" preload="none" type="video/mp4" src="blob:https://www.instagram.com/4feb10a9-7a9d-4d3c-b63a-6773a391bded" loop="" style="display: block;"></video>

于是就很好奇, 查看了一下, 它使用分段的 mp4 进行拼接成的视频, 视频链接如下:

links = [
    'https://scontent-hkt1-2.cdninstagram.com/v/t66.30100-16/48765482_566184564823119_7249730986057316274_n.mp4?_nc_ht=scontent-hkt1-2.cdninstagram.com&_nc_cat=1&_nc_ohc=4Ba61mlOYE4AX9Ym6rG&edm=APfKNqwBAAAA&ccb=7-4&oh=00_AT-ddAJEjKnOOOGslcGOVkxctcfcao29aLwNDjjWSC7d5g&oe=627D7BBA&_nc_sid=74f7ba&bytestart=0&byteend=782',
    'https://scontent-hkt1-2.cdninstagram.com/v/t66.30100-16/48765482_566184564823119_7249730986057316274_n.mp4?_nc_ht=scontent-hkt1-2.cdninstagram.com&_nc_cat=1&_nc_ohc=4Ba61mlOYE4AX9Ym6rG&edm=APfKNqwBAAAA&ccb=7-4&oh=00_AT-ddAJEjKnOOOGslcGOVkxctcfcao29aLwNDjjWSC7d5g&oe=627D7BBA&_nc_sid=74f7ba&bytestart=783&byteend=970',
    'https://scontent-hkt1-2.cdninstagram.com/v/t66.30100-16/48765482_566184564823119_7249730986057316274_n.mp4?_nc_ht=scontent-hkt1-2.cdninstagram.com&_nc_cat=1&_nc_ohc=4Ba61mlOYE4AX9Ym6rG&edm=APfKNqwBAAAA&ccb=7-4&oh=00_AT-ddAJEjKnOOOGslcGOVkxctcfcao29aLwNDjjWSC7d5g&oe=627D7BBA&_nc_sid=74f7ba&bytestart=971&byteend=22557',
    'https://scontent-hkt1-2.cdninstagram.com/v/t66.30100-16/48765482_566184564823119_7249730986057316274_n.mp4?_nc_ht=scontent-hkt1-2.cdninstagram.com&_nc_cat=1&_nc_ohc=4Ba61mlOYE4AX9Ym6rG&edm=APfKNqwBAAAA&ccb=7-4&oh=00_AT-ddAJEjKnOOOGslcGOVkxctcfcao29aLwNDjjWSC7d5g&oe=627D7BBA&_nc_sid=74f7ba&bytestart=22558&byteend=161856',
    'https://scontent-hkt1-2.cdninstagram.com/v/t66.30100-16/48765482_566184564823119_7249730986057316274_n.mp4?_nc_ht=scontent-hkt1-2.cdninstagram.com&_nc_cat=1&_nc_ohc=4Ba61mlOYE4AX9Ym6rG&edm=APfKNqwBAAAA&ccb=7-4&oh=00_AT-ddAJEjKnOOOGslcGOVkxctcfcao29aLwNDjjWSC7d5g&oe=627D7BBA&_nc_sid=74f7ba&bytestart=161857&byteend=304637',
  ];

于是自己写了下面这段代码, 手动拼接然后进行下载:

  var blobs = await Promise.all(links.map(async link=> {
    return await fetch(link).then(r=>r.blob())
  }));
  var combinedVideoBlob = blobs.reduce((a, b) => new Blob([a, b], { type: 'video/mp4' }));
  var downloadA = document.createElement("a");
  downloadA.download = "a.mp4";
  downloadA.href = window.webkitURL.createObjectURL(combinedVideoBlob);
  downloadA.click();

最终下载成功, 但是视频只有声音没有图像.

  1. 想知道代码哪里出了问题, 为什么视频没有图像?
  2. 有什么方便的浏览器插件, 检测到视频会悬浮一个下载按钮, 获取下载直链
  3. 有什么方式避免用户(开发者)打开 devtools 找到视频地址进行下载?
2230 次点击
所在节点    程序员
6 条回复
wunonglin
2022-05-11 16:13:46 +08:00
大概率是 mediastream 、http range
LeegoYih
2022-05-11 16:17:40 +08:00
you-get 支持下载视频和图片: https://github.com/soimort/you-get/
ynyounuo
2022-05-11 16:24:00 +08:00
1. 换成移动端的 UA 直接在 Network 的 media filter 下就有完整视频链接了
2. 多了去了
3. DASH/HLS + CENC 加密
yanyumihuang
2022-05-11 17:07:09 +08:00
Windows idm ,mac 不知道
findex
2022-05-11 17:50:38 +08:00
firefox 有插件,可以下载 instagram 视频,而且支持拼接。没必要自己写了。
FaiChou
2022-05-12 09:27:48 +08:00
@LeegoYih 之前发过帖子, you-get 不好用了, 用 yt-dlp 代替 ( https://v2ex.com/t/818153#reply20).

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/852210

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX