Як завантажити відео з URL-адресою blob?


94

Я намагаюся завантажити відео з URL-адресою src blob:https%3A//www.youtube.com/23aea5c8-9ae2-40dc-9417-e675ea99b386.

Чи є процес, який можна дотримуватися для завантаження всіх цього типу відео?


Якщо ви хочете завантажити відео з YouTube, використовуйте такі розширення, як Video Downloadhelper (Firefox)
Ganesh R.

я хочу завантажити з vimeo url.
vinesh

Винеш, спробуйте перейти на веб-сайт vimeo і почати відтворення відео, яке потрібно завантажити. Video DownloadHelper виявить це і дасть вам можливість завантажити його. Я спробував це.
Ганеш Р.

Не вдалося. коли я почав відтворювати відео, я побачив декілька пропозицій щодо відео з розширення, про яке ви згадали кожен із приблизно 2 Мб. коли я завантажив частину, мені не вдалося відтворити цей невеликий файл. Я отримував помилку, що файл пошкоджений.
vinesh

поставити посилання в коментарях
Ганеш Р.

Відповіді:


69

Я знайшов спосіб , щоб завантажити відео з blob urlв Vimeo(читання тут я зрозумів , як це робити). Тут я пишу прості кроки. Я використовую Google Chrome:

  1. Відкрийте More ToolsDeveloper Tools
  2. Перевірте, чи є у відеотезі щось подібне:

    <video preload="" src="blob:https://player.vimeo.com/XXXXXXXX-XXXX-XXXX-XXXX-XXXXXXXXXXXX"></video>
    
  3. Скопіюйте src тегу iframe, якщо такий є, щось на зразок, http://player.vimeo.com/video/XYZякщо ви знайшли його, ви можете перейти безпосередньо до точки 7, інакше виконайте кроки 4, 5, 6.
  4. Тепер шукайте цей рядок https://skyfire.vimeocdn.com/.../master.json?base64_init=1всередині сторінки (використовуючи Перегляд розробника), ви повинні знайти його у функції javascript, наприклад:

    (function(e,a){var t={"cdn_url":"https://f.vimeocdn.com","view":1,"request":{"files":{"dash":{"origin":"gcs","url":"https://48skyfiregce-a.akamaihd.net/.../master.json?base64_init=1","cdn":"
    
  5. Скопіюйте посилання всередині поля URL на новій вкладці Chrome, наприклад, https://48skyfiregce-a.akamaihd.net/.../master.json?base64_init=1відкрийте його в браузері, він відкриє файл json таким чином:

    {
        "clip_id": XYZ,
        "base_url": "../",
        "video": [
                     { ... ... ...
    
  6. Тепер складіть URL-адресу зі своїм ідентифікатором XYZтак:https://player.vimeo.com/video/XYZ

  7. Замініть blob:https://player.vimeo.com/XXXXXXXX-XXXX-XXXX-XXXX-XXXXXXXXXXXXвсередині тегу відео на останню URL-адресу (створену на попередньому кроці №6).
  8. Тепер ви помітите, що магічно поле src всередині відеотега змінилося (якщо цього не зробити, спробуйте зробити крок 7 кілька разів) ...

    <video preload="none" src="https://fpdl.vimeocdn.com/vimeo-prod-skyfire-std-us/XX/XXX/X/XXXXXXXX/XXXXXXXXX.mp4?token=abcdefg"></video>
    
  9. Використовуйте це нове посилання, щоб завантажити його безпосередньо, це приблизно так: https://fpdl.vimeocdn.com/vimeo-prod-skyfire-std-us/XX/XXX/X/XXXXXXXX/XXXXXXXXX.mp4?token=abcdefg


7
Вражає. Як ви це зрозуміли?
gronostaj

1
На кроці 7, що ви маєте на увазі під "останнім URL-адресом всередині html"?
joaorodr84

6
Працює чудово, але хитрість полягає в тому, що іноді вам доведеться кілька разів замінити значення "src", щоб створити посилання для завантаження.
Ашріт

19
Наразі для Vimeo це набагато простіше і не вимагає всіх кроків. Просто відкрийте відео Vimeo, знайдіть <video>тег у структурі DOM інструментів розробки та змініть srcатрибут з blob:...на x. Нічого не станеться - це нормально. Тепер змінити його знову, на y. Chrome перетворить його "магічно" на URL-адресу, наприклад, на кроці 8 або 9. :-)
StanE

3
@StanE це працює як шарм, у Firefox теж, і, безумовно, швидше ...
ling

10

Ця відповідь стосується URL-адрес Twitter -

  1. Клацніть правою кнопкою миші на відео та натисніть «Оглянути елементи -

Ви знайдете такий код

<div id="playerContainer" class="player-container full-screen-enabled" data-config="{&quot;is_360&quot;:false,&quot;duration&quot;:28617,&quot;scribe_widget_origin&quot;:true,&quot;heartbeatEnabled&quot;:true,&quot;video_url&quot;:&quot;https:\/\/video.twimg.com\/ext_tw_video\/844504104512749568\/pu\/pl\/e91Du5N2TZ09ZaW_.m3u8&quot;,&quot;disable_embed&quot;:&quot;0&quot;,&quot;videoInfo&quot;:{&quot;title&quot;:null,&quot;description&quot;:null,&quot;publisher&quot;:{&quot;screen_name&quot;:&quot;MountainButorac&quot;,&quot;name&quot;:&quot;Mountain Butorac&quot;,&quot;profile_image_url&quot;:&quot;https:\/\/pbs.twimg.com\/profile_images\/808318456701521920\/vBvlAASx_normal.jpg&quot;}},&quot;cardUrl&quot;:&quot;https:\/\/t.co\/SdSorop3uN&quot;,&quot;content_type&quot;:&quot;application\/x-mpegURL&quot;,&quot;owner_id&quot;:&quot;14120461&quot;,&quot;looping_enabled&quot;:true,&quot;show_cookie_override_en&quot;:true,&quot;visit_cta_url&quot;:null,&quot;scribe_playlist_url&quot;:&quot;https:\/\/twitter.com\/MountainButorac\/status\/844505243538931714\/video\/1&quot;,&quot;source_type&quot;:&quot;consumer&quot;,&quot;image_src&quot;:&quot;https:\/\/pbs.twimg.com\/ext_tw_video_thumb\/844504104512749568\/pu\/img\/FFt3qkbeOh0RlGfZ.jpg&quot;,&quot;heartbeatIntervalInMs&quot;:5000.0,&quot;use_tfw_live_heartbeat_event_category&quot;:true,&quot;video_loading_timeout&quot;:45000.0,&quot;status&quot;:{&quot;created_at&quot;:&quot;Wed Mar 22 11:05:14 +0000 2017&quot;,&quot;id&quot;:844505243538931714,&quot;id_str&quot;:&quot;844505243538931714&quot;,&quot;text&quot;:&quot;Took my Goddaughter to meet the pope. She stole his hat! https:\/\/t.co\/SdSorop3uN&quot;,&quot;truncated&quot;:false,&quot;entities&quot;:{&quot;hashtags&quot;:[],&quot;symbols&quot;:[],&quot;user_mentions&quot;:[],&quot;urls&quot;:[],&quot;media&quot;:[{&quot;id&quot;:844504104512749568,&quot;id_str&quot;:&quot;844504104512749568&quot;,&quot;indices&quot;:[57,80],&quot;media_url&quot;:&quot;http:\/\/pbs.twimg.com\/ext_tw_video_thumb\/844504104512749568\/pu\/img\/FFt3qkbeOh0RlGfZ.jpg&quot;,&quot;media_url_https&quot;:&quot;https:\/\/pbs.twimg.com\/ext_tw_video_thumb\/844504104512749568\/pu\/img\/FFt3qkbeOh0RlGfZ.jpg&quot;,&quot;url&quot;:&quot;https:\/\/t.co\/SdSorop3uN&quot;,&quot;display_url&quot;:&quot;pic.twitter.com\/SdSorop3uN&quot;,&quot;expanded_url&quot;:&quot;https:\/\/twitter.com\/MountainButorac\/status\/844505243538931714\/video\/1&quot;,&quot;type&quot;:&quot;photo&quot;,&quot;sizes&quot;:{&quot;small&quot;:{&quot;w&quot;:340,&quot;h&quot;:604,&quot;resize&quot;:&quot;fit&quot;},&quot;thumb&quot;:{&quot;w&quot;:150,&quot;h&quot;:150,&quot;resize&quot;:&quot;crop&quot;},&quot;large&quot;:{&quot;w&quot;:576,&quot;h&quot;:1024,&quot;resize&quot;:&quot;fit&quot;},&quot;medium&quot;:{&quot;w&quot;:576,&quot;h&quot;:1024,&quot;resize&quot;:&quot;fit&quot;}}}]},&quot;source&quot;:&quot;\u003ca href=\&quot;http:\/\/twitter.com\/download\/iphone\&quot; rel=\&quot;nofollow\&quot;\u003eTwitter for iPhone\u003c\/a\u003e&quot;,&quot;in_reply_to_status_id&quot;:null,&quot;in_reply_to_status_id_str&quot;:null,&quot;in_reply_to_user_id&quot;:null,&quot;in_reply_to_user_id_str&quot;:null,&quot;in_reply_to_screen_name&quot;:null,&quot;geo&quot;:null,&quot;coordinates&quot;:null,&quot;place&quot;:null,&quot;contributors&quot;:null,&quot;retweet_count&quot;:0,&quot;favorite_count&quot;:0,&quot;favorited&quot;:false,&quot;retweeted&quot;:false,&quot;possibly_sensitive&quot;:false,&quot;lang&quot;:&quot;en&quot;},&quot;show_cookie_override_all&quot;:true,&quot;video_session_enabled&quot;:false,&quot;media_id&quot;:&quot;844504104512749568&quot;,&quot;view_counts&quot;:null,&quot;statusTimestamp&quot;:{&quot;local&quot;:&quot;4:05 AM - 22 Mar 2017&quot;},&quot;media_type&quot;:1,&quot;user&quot;:{&quot;screen_name&quot;:&quot;MountainButorac&quot;,&quot;name&quot;:&quot;Mountain Butorac&quot;,&quot;profile_image_url&quot;:&quot;https:\/\/pbs.twimg.com\/profile_images\/808318456701521920\/vBvlAASx_bigger.jpg&quot;},&quot;watch_now_cta_url&quot;:null,&quot;tweet_id&quot;:&quot;844505243538931714&quot;}" data-source-type="consumer">

2.Копіюйте Вставте вище код у блокнот ++. Замінити всі &quot;з "і \/т - й /в Notepad ++. (Використовуйте CTRL + H)

Ви отримаєте щось на кшталт

{
    "is_360": false,
    "duration": 28617,
    "scribe_widget_origin": true,
    "heartbeatEnabled": true,
    "video_url": "https://video.twimg.com/ext_tw_video/844504104512749568/pu/pl/e91Du5N2TZ09ZaW_.m3u8",

    "disable_embed": "0",
    "videoInfo": {
        "title": null,
        "description": null,
        "publisher": {
            "screen_name": "MountainButorac",
            "name": "Mountain Butorac",
            "profile_image_url": "https://pbs.twimg.com/profile_images/808318456701521920/vBvlAASx_normal.jpg"
        }
    },
    "cardUrl": "https://t.co/SdSorop3uN",
    "content_type": "application/x-mpegURL",
    "owner_id": "14120461",
    "looping_enabled": true,
    "show_cookie_override_en": true,
    "visit_cta_url": null,
    "scribe_playlist_url": "https://twitter.com/MountainButorac/status/844505243538931714/video/1",
    "source_type": "consumer",
    "image_src": "https://pbs.twimg.com/ext_tw_video_thumb/844504104512749568/pu/img/FFt3qkbeOh0RlGfZ.jpg",
    "heartbeatIntervalInMs": 5000.0,
    "use_tfw_live_heartbeat_event_category": true,
    "video_loading_timeout": 45000.0,
    "status": {
        "created_at": "Wed Mar 22 11:05:14 +0000 2017",
        "id": 844505243538931714,
        "id_str": "844505243538931714",
        "text": "Took my Goddaughter to meet the pope. She stole his hat! https://t.co/SdSorop3uN",
        "truncated": false,
        "entities": {
            "hashtags": [],
            "symbols": [],
            "user_mentions": [],
            "urls": [],
            "media": [{
                "id": 844504104512749568,
                "id_str": "844504104512749568",
                "indices": [57, 80],
                "media_url": "http://pbs.twimg.com/ext_tw_video_thumb/844504104512749568/pu/img/FFt3qkbeOh0RlGfZ.jpg",
                "media_url_https": "https://pbs.twimg.com/ext_tw_video_thumb/844504104512749568/pu/img/FFt3qkbeOh0RlGfZ.jpg",
                "url": "https://t.co/SdSorop3uN",
                "display_url": "pic.twitter.com/SdSorop3uN",
                "expanded_url": "https://twitter.com/MountainButorac/status/844505243538931714/video/1",
                "type": "photo",
                "sizes": {
                    "small": {
                        "w": 340,
                        "h": 604,
                        "resize": "fit"
                    },
                    "thumb": {
                        "w": 150,
                        "h": 150,
                        "resize": "crop"
                    },
                    "large": {
                        "w": 576,
                        "h": 1024,
                        "resize": "fit"
                    },
                    "medium": {
                        "w": 576,
                        "h": 1024,
                        "resize": "fit"
                    }
                }
            }]
        },
        "source": "\u003ca href=\"http://twitter.com/download/iphone\" rel=\"nofollow\"\u003eTwitter for iPhone\u003c/a\u003e",
        "in_reply_to_status_id": null,
        "in_reply_to_status_id_str": null,
        "in_reply_to_user_id": null,
        "in_reply_to_user_id_str": null,
        "in_reply_to_screen_name": null,
        "geo": null,
        "coordinates": null,
        "place": null,
        "contributors": null,
        "retweet_count": 0,
        "favorite_count": 0,
        "favorited": false,
        "retweeted": false,
        "possibly_sensitive": false,
        "lang": "en"
    },
    "show_cookie_override_all": true,
    "video_session_enabled": false,
    "media_id": "844504104512749568",
    "view_counts": null,
    "statusTimestamp": {
        "local": "4:05 AM - 22 Mar 2017"
    },
    "media_type": 1,
    "user": {
        "screen_name": "MountainButorac",
        "name": "Mountain Butorac",
        "profile_image_url": "https://pbs.twimg.com/profile_images/808318456701521920/vBvlAASx_bigger.jpg"
    },
    "watch_now_cta_url": null,
    "tweet_id": "844505243538931714"
}

Зверху формат JSON див. Значення video_url

https://video.twimg.com/ext_tw_video/844504104512749568/pu/pl/e91Du5N2TZ09ZaW_.m3u8

Проблема полягає в тому, що після 1 серпня 2016 року Twitter більше не використовує .mp4 відео, а перетворюється на новий HLS, адаптивний-потоковий формат, з розширенням .m3u8 .

Файли .m3u8 - це лише обгортка текстових файлів, вони дуже малі (300-500 байт), і коли ви відкриваєте їх текстовим редактором, вони містять посилання на різні розміри відео

  1. Відкрийте файл m3u8 у блокноті ++, він міститиме такий код

EXTM3U EXT-X-НЕЗАЛЕЖНІ-СЕГМЕНТИ EXT-X-STREAM-INF: PROGRAM-ID = 1, BANDWIDTH = 256000, РЕЗОЛЮЦІЯ = 180x320, CODECS = "mp4a.40.2, avc1.42001f" / ext_tw_video / 8445046845457 / pu445468445457 180x320 / _Z42SY5zwMlLdFYx.m3u8 EXT-X-STREAM-INF: ПРОГРАМА-ID = 1, Bandwidth = 832000, дозвіл = 360x640, кодеки = "mp4a.40.2, avc1.42001f" / ext_tw_video / 844504104512749568 / в.о. / пл / 360x640 / - Phfjbbx2yinirLi.m3u8

  1. Скопіюйте відповідне посилання зверху відповідно до необхідної роздільної здатності. Повторіть той же крок, поки у вас не буде файл .ts . Завантажте файл .ts (відеофайл).

Що ви маєте на увазі, "ви отримаєте щось на зразок" - звідки?
Користувач

@User з коду над ним, який починається як<div id="playerContainer"
Пірат X

3
Гей, на кроці 4, що ви маєте на увазі під "копією відповідного посилання"? Це неправдива URL-адреса, і я не можу знайти, як отримати відео за допомогою неї. РЕДАКЦІЯ: Добре, правда, я знайшов. Слід зазначити, що перед цим потрібно поставити " video.twimg.com " та отримати доступ до URL-адреси.
Ельцо

Якщо ви не можете знайти id="playerContainer"елемент, шукайте og:video:urlта відкрийте URL у вмісті та перевірте джерело цього.
guillefix

Ще один спосіб зробити це на Twitter - це запустити document.querySelector('video').srcна вкладці консолі інструментів для розробників браузера.
Farzad YZ

8
<video src="blob:https://www.example.tv/xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx">
  <source src="https://cdn.example.tv/api/media/tv/xyzxyz/index" type="application/x-mpegurl">
</video>

Я також мав blob:URL у video/@src, але спостерігаючи Developer tools> Networkпід час відтворення виявилося, що video/source/@srcце URL для m3u8списку відтворення.

m3u8-Backed відео можна легко завантажити, або:

  • ffplay -i "https://cdn.example.tv/api/media/tv/xyzxyz/1080/index.m3u8"
  • ffmpeg -i "https://cdn.example.tv/api/media/tv/xyzxyz/1080/index.m3u8" -codec copy file.mkv

tl; dr - URL-адреса блобу звучить як двійковий файл, який ви хочете отримати, але може бути простіший спосіб отримати відео. Просто перегляньте вкладку «Мережа» в інструментах Dev під час відтворення відео, щоб побачити, що ви насправді отримуєте.


1
Працює на моїй машині! І ви можете поставити кілька видів вхідних потоків, -i <URL> -i <URL> -i <URL>щоб об’єднати відео, аудіо та субтитри в один вихід :)
mcandre

@mcandre Так, це гарна порада. Ви також можете знайти m3u8 металіста (тобто файл m3u8, що посилається на інші файли m3u8), і ffmpeg завантажить його і належним чином об'єднає, тому вам не потрібно вручну вказувати кілька входів -i.
Властиміл Овчачик

0

Я знайшов інший спосіб завантаження відео з blob urlін Vimeo(див іншої відповіді на цій сторінці).

Це рішення підходить лише в тому випадку, якщо ви хочете просто відео без звуків!

Отже, якщо ви хочете завантажити просто відео Vimeo (часто без звуків), я можу підтвердити, що це розширення Google Chrome працює дуже добре: Flash Video Downloader .

Використовуючи наш веб-сайт, ви визнаєте, що прочитали та зрозуміли наші Політику щодо файлів cookie та Політику конфіденційності.
Licensed under cc by-sa 3.0 with attribution required.