将blob URL转换为普通URL

Jac*_*cob 82 javascript url blob

我的页面生成如下URL:"blob:http%3A//localhost%3A8383/568233a1-8b13-48b3-84d5-cca045ae384f"如何将其转换为普通地址?

我使用它作为一个<img>src属性.

小智 144

从JavaScript创建的URL Blob无法转换为"普通"URL.

一个blob:URL并不是指在服务器上存在的数据,它指的是您的浏览器目前在存储器中,当前页面的数据.它不会在其他页面上提供,在其他浏览器中不可用,并且不会从其他计算机上获得.

因此,将BlobURL 转换为"普通"URL 通常没有意义.如果您想要一个普通的URL,您必须将数据从浏览器发送到服务器并让服务器像普通文件一样使它可用.

可以将blob:URL转换为data:URL,至少在Chrome中.您可以使用AJAX请求从blob:URL中"获取"数据(即使它实际上只是将其从浏览器的内存中拉出来,而不是发出HTTP请求).

这是一个例子:

var blob = new Blob(["Hello, world!"], { type: 'text/plain' });
var blobUrl = URL.createObjectURL(blob);

var xhr = new XMLHttpRequest;
xhr.responseType = 'blob';

xhr.onload = function() {
   var recoveredBlob = xhr.response;

   var reader = new FileReader;

   reader.onload = function() {
     var blobAsDataUrl = reader.result;
     window.location = blobAsDataUrl;
   };

   reader.readAsDataURL(recoveredBlob);
};

xhr.open('GET', blobUrl);
xhr.send();
Run Code Online (Sandbox Code Playgroud)

data:URL可能不是"正常"的意思,可能会有问题.但是,它们的工作方式与普通URL一样,因为它们可以共享; 它们并不特定于当前的浏览器或会话.

  • @ bhh1988看起来[媒体源扩展规范](https://dvcs.w3.org/hg/html-media/raw-file/tip/media-source/media-source.html)允许blob网址为JavaScript管理的媒体流创建.这些不对应于静态数据,如本文中讨论的blob URL,因此行为不同,但它们仍然引用本地信息,而不是直接引用服务器上的数据. (16认同)
  • 如果blob网址没有指向服务器数据,那么Youtube视频的src网址如何显示:src ="blob:https%3A // www.youtube.com/44f26667-03f1-4978-9eed-af0cbf11dd67"(在铬) (11认同)
  • @ bhh1988这是一个非常有趣的发现.我不确定那里发生了什么.如果我尝试使用XMLHttpRequest检索其src blob URL,如本文所述,则不返回任何内容.我的猜测是(a)他们生成任何空的Blob URL以用作占位符,同时从另一个源提供数据或(b)Blob以某种方式充当加密数据的代理(通过HTML5加密媒体扩展).但是,我不确定这些中的任何一个在实践中是如何实际完成的. (5认同)
  • 我收到“不允许将顶部框架导航到数据 URL: data:text/plain;base64,...”错误。我得到了数据,但不允许使用`window.location`... (3认同)
  • 嗯,听起来不错。这很令人困惑,因为 url 看起来真实且有意,但如果它只是一个占位符,那么 src 的值是什么并不重要。 (2认同)

小智 15

另一种从blob url创建数据网址的方法可能是使用canvas.

var canvas = document.createElement("canvas")
var context = canvas.getContext("2d")
context.drawImage(img, 0, 0) // i assume that img.src is your blob url
var dataurl = canvas.toDataURL("your prefer type", your prefer quality)
Run Code Online (Sandbox Code Playgroud)

正如我在mdn中看到的那样,canvas.toDataURL受到浏览器的支持.(除了<9,总是<9)

  • 请注意,这当然仅适用于图像数据,并且某些元数据可能会丢失! (17认同)
  • 这样做会创建一个链接,但如果你遵循它,你只会得到一个黑框。 (2认同)

Gas*_* J. 10

对于那些来到这里寻找下载 blob url 视频/音频的方法的人来说,这个答案对我有用。简而言之,您需要通过Chrome -> Network 选项卡在所需网页上找到一个 *.m3u8 文件并将其粘贴到VLC 播放器中

另一个指南向您展示了如何使用 VLC 播放器保存流


更新:

从 blob url 下载视频的另一种方法是使用批量下载器并将文件连接在一起。

下载视频部分

  1. 在 Chrome 开发工具中打开网络选项卡

在此处输入图片说明

  1. 重新加载网页
  2. 过滤 .m3u8 文件

在此处输入图片说明

  1. 查看所有过滤的文件并找到“.ts”文件的播放列表。它应该是这样的:

在此处输入图片说明

  1. 您需要以某种方式提取这些链接。手动下载和编辑文件或使用您喜欢的任何其他方法。如您所见,这些链接非常相​​似,唯一不同的是视频的序列号:“s- 0 -v1-a1.ts”、“s- 1 -v1-a1.ts”等。

    https://some-website.net/del/8cf.m3u8/s-0-v1-a1.ts

    https://some-website.net/del/8cf.m3u8/s-1-v1-a1.ts

    https://some-website.net/del/8cf.m3u8/s-2-v1-a1.ts?

依此类推,直到 .m3u8 播放列表文件中的最后一个链接。这些 .ts 文件实际上是您的视频。您需要下载所有这些。

  1. 对于批量下载,我更喜欢使用 Chrome 的 Simple Mass Downloader 扩展程序(https://chrome.google.com/webstore/detail/simple-mass-downloader/abdkkegmcbiomijcbdaodaflgehfffed

  2. 如果您选择使用 Simple Mass Downloader,则需要:

    一种。选择模式 URL

在此处输入图片说明

湾 在地址字段中输入您的链接,只需做一个修改:链接中为每个下一个视频更改的部分需要替换为方括号 [0:400] 中的模式,其中 0 是第一个文件名,400 是最后一个。所以你的链接应该看起来像这样https://some-website.net/del/8cf.m3u8/s-[0:400]-v1-a1.ts

然后点击导入按钮将这些链接添加到 Mass Downloader 的下载列表中。

在此处输入图片说明

C。下一个操作可能会要求您提供下载的每个视频的目标文件夹。因此,强烈建议在 Chrome 设置中指定默认下载文件夹,并在 Chrome 设置中禁用选择目标选项。这将为您节省很多时间!此外,您可能希望指定这些文件所在的文件夹:

在此处输入图片说明

C1. 单击“全选”复选框以从“下载列表”中选择所有文件。

在此处输入图片说明

C2. 单击 SMD 扩展窗口右下角的下载按钮。它将带您到下一个选项卡开始下载

在此处输入图片说明

C3. 选择点击开始。这会将所有视频自动下载到下载文件夹中。

在此处输入图片说明

这就对了!只需等待所有文件下载完毕,您就可以通过 VLC 播放器或任何其他支持 .ts 格式的播放器观看它们。但是,如果您想拥有一个视频而不是已下载的视频,则需要将所有这些迷你视频连接在一起

加入影片部分

由于我在 Mac 上工作,因此我不知道您将如何在 Windows 上执行此操作。如果您是 Windows 用户并且想要合并视频,请随时谷歌搜索 Windows 解决方案。后续步骤仅适用于 Mac。

  1. 在要保存新视频的文件夹中打开终端
  2. 类型:cat并点击space
  3. 打开您下载.ts视频的文件夹。选择.ts您要加入的所有视频(使用鼠标或cmd+A
  4. 将它们拖放到终端中
  5. space
  6. >
  7. Space
  8. 输入新视频的名称,例如my_new_video.ts。请注意,格式必须与原始视频中的格式相同,否则转换会花费很长时间甚至可能会失败!
  9. 击中Enter。等待终端完成加入过程并享受观看您的视频!

  • 这项工作*ed* ...直到聪明的 HTML/JS 专家开始完全避免“*.m3u8”。真糟糕! (3认同)