2017-09-07 96 views
0

我在找上如何去在角2角2 - 从字节数组

我(在客户端目前为Base64字符串)保存多个文件以zip目录中的一些方向创建邮编目前从我的webapi获取文件作为base64字符串。我使用pdf-viewer将字符串转换为字节[]以供查看。我还允许用户使用file-saver保存/打印PDF。

现在,我想允许用户将所有选定的文件下载到zip文件夹中。不幸的是,我不完全理解blob等,因此,如何解决这个问题需要一些帮助。请记住,从webapi返回的对象包含每个文件的base64字符串,但可以很容易地转换为byte []和blob。

回答

0

对于那些可能处于这个位置的人,我提出的解决方案利用了我现有的代码,只需要添加JSZip即可。代码为:

public downloadAllFiles() { 
    console.log("Downloading All Files"); 
    var fileName = this.defaultDataService.defaultDataBase + "-" + this.selectedYear.path + ".zip"; 
    var zip = new JSZip(); 

    var year = zip.folder(this.selectedYear.path); 

    for (var i = 0; i < this.selectedTypes.length; i++) {    
     var subDir = year.folder(this.selectedTypes[i].path); 
     for (var j = 0; j < this.selectedTypes[i].pdfList.length; j++) { 
      subDir.file(this.selectedTypes[i].pdfList[j].name + ".pdf", this.createPdfBlob(this.convertBase64ToBytes(this.selectedTypes[i].pdfList[j].bytes))); 
     } 
    } 

    zip.generateAsync({ type: "blob" }) 
     .then(function (blob) { 
      FileSaver.saveAs(blob, fileName); 
     }); 
} 

convertBase64ToBytes(data: string) { 
    let byteCharacters = atob(data); 
    let byteNumbers = new Array(byteCharacters.length); 

    for (var i = 0; i < byteCharacters.length; i++) { 
     byteNumbers[i] = byteCharacters.charCodeAt(i); 
    } 

    let byteArray = new Uint8Array(byteNumbers); 
    return byteArray; 
} 

createPdfBlob(src: any) { 
    const byteArrays = []; 
    byteArrays.push(src); 
    return new Blob(byteArrays, { type: 'application/pdf' }); 
}