Angular.js字节数组到Blob

拉尼·拉德克利夫(Rani Radcliff)

我正在尝试使用Angular和PDF.js查看保存在SQL数据库中的二进制数据中的PDF。从服务返回的数据如下所示:

在此处输入图片说明

本质上,我相信我需要创建一个objectURL才能使其正常工作,但是我不确定如何将其转换为Blob。我尝试了以下方法:

        .success(function (response) {
        var fileName = response[0].FileName;
        var fileImage = response[0].binFileImage;
        var blob = new Blob(fileImage, { type: 'application/pdf' });
        var fileURL = URL.createObjectURL(blob);

我使用以下内容转换图像文件:

 function base64ArrayBuffer(arrayBuffer) {
    var base64 = ''
    var encodings = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/'

    var bytes = new Uint8Array(arrayBuffer)
    var byteLength = bytes.byteLength
    var byteRemainder = byteLength % 3
    var mainLength = byteLength - byteRemainder

    var a, b, c, d
    var chunk

    // Main loop deals with bytes in chunks of 3
    for (var i = 0; i < mainLength; i = i + 3) {
        // Combine the three bytes into a single integer
        chunk = (bytes[i] << 16) | (bytes[i + 1] << 8) | bytes[i + 2]

        // Use bitmasks to extract 6-bit segments from the triplet
        a = (chunk & 16515072) >> 18 // 16515072 = (2^6 - 1) << 18
        b = (chunk & 258048) >> 12 // 258048   = (2^6 - 1) << 12
        c = (chunk & 4032) >> 6 // 4032     = (2^6 - 1) << 6
        d = chunk & 63               // 63       = 2^6 - 1

        // Convert the raw binary segments to the appropriate ASCII encoding
        base64 += encodings[a] + encodings[b] + encodings[c] + encodings[d]
    }

    // Deal with the remaining bytes and padding
    if (byteRemainder == 1) {
        chunk = bytes[mainLength]

        a = (chunk & 252) >> 2 // 252 = (2^6 - 1) << 2

        // Set the 4 least significant bits to zero
        b = (chunk & 3) << 4 // 3   = 2^2 - 1

        base64 += encodings[a] + encodings[b] + '=='
    } else if (byteRemainder == 2) {
        chunk = (bytes[mainLength] << 8) | bytes[mainLength + 1]

        a = (chunk & 64512) >> 10 // 64512 = (2^6 - 1) << 10
        b = (chunk & 1008) >> 4 // 1008  = (2^6 - 1) << 4

        // Set the 2 least significant bits to zero
        c = (chunk & 15) << 2 // 15    = 2^4 - 1

        base64 += encodings[a] + encodings[b] + encodings[c] + '='
    }

    return base64
}

我尝试将其用于PDF,但不确定是否正确的格式。上面的函数将字节数组转换为:

JVBERi0xLjQNCiX5+prnDQo3IDAgb2JqDQo8PA0KL0UgMzU0ODENCi9IIFsgMTM3OCAxNjMgXQ0KL0wgMzc3NzkNCi9MaW5lYXJpemVkIDENCi9OIDINCi9PIDEwDQovVCAzNzU4OQ0KPj4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICANCmVuZG9iag0KDQp4cmVmDQo3IDExDQowMDAwMDAwMDE3IDAwMDAwIG4NCjAwMDAwMDEyN... (shortened).

我不太确定要如何转换数据,以便可以使用它来创建对象网址,以便查看pdf。非常感谢您的协助!

拉尼·拉德克利夫(Rani Radcliff)

可能有一种更简单的方法来执行此操作,但这在IE和Chrome中有效。

  1. 首先,我将字节数组转换为base64。
  2. 接下来,我将base64转换为Uint8Array。
  3. 然后,我显示文件。

这是对我有用的代码:

    lwsService.getdocument(id)
    .success(function (response) {
       var byteArray = new Uint8Array(response[0].binFileImage);
       var blob = new Blob([byteArray], { type: 'application/pdf' });
        if (window.navigator && window.navigator.msSaveOrOpenBlob) {
          window.navigator.msSaveOrOpenBlob(blob);
        } else {
          var objectUrl = URL.createObjectURL(blob);
          window.open(objectUrl);
        }

我希望这对其他人有帮助。

本文收集自互联网,转载请注明来源。

如有侵权,请联系[email protected] 删除。

编辑于
0

我来说两句

0条评论
登录后参与评论

相关文章

来自分类Dev

在angular js中将字节数组显示为图像

来自分类Dev

将字节数组转换为 angular6 中的图像

来自分类Dev

如何使用 angular 7 在 IE 11 中打印字节数组

来自分类Dev

字节数组到布尔数组

来自分类Dev

固定对象到字节数组

来自分类Dev

Clojure,文件到字节数组?

来自分类Dev

WPF WriteableBitmap到字节数组

来自分类Dev

BigIntegers的ArrayList到字节数组

来自分类Dev

图像到字节数组-ExternalException

来自分类Dev

字节数组到BitmapImage WP

来自分类Dev

编码图像到字节数组

来自分类Dev

图片框到字节数组

来自分类Dev

ZipEntry到字节数组

来自分类Dev

Angular 7 File Saver 使用编码的字节数组保存文件而不是将其转换为 CSV 格式

来自分类Dev

C#字节数组到Javascript Blob创建并自动下载PDF文件

来自分类Dev

AS3字节数组到C#字节数组

来自分类Dev

AS3字节数组到C#字节数组

来自分类Dev

MySQL和Java:检索到的字节数组与存储时的字节数组不同

来自分类Dev

字节字符串到字节数组

来自分类Dev

字节数组[]到字节在Java中可能吗?

来自分类Dev

字节数组到字节的转换错误

来自分类Dev

字节数组[]到字节在Java中可能吗?

来自分类Dev

读取文件到字节数组时的冗余字节

来自分类Dev

将字节数组插入Blob列

来自分类Dev

OracleDataReader返回BLOB列的空字节数组

来自分类Dev

POJO到字节数组与POJO到JSON

来自分类Dev

ARGB int数组到CMYKA字节数组的转换

来自分类Dev

将字节数组作为std :: vector <char>从Node.js传递到C ++插件

来自分类Dev

可观察字节数组到对象的转换