我在使文件下载在我的应用程序中正常工作时遇到了一些麻烦。要下载文件,我正在使用API进行新的调用,以将数据输入到应用程序中。我已经使用Postman测试了该API,并且由于可以通过该调用下载文件,因此它似乎可以正常工作。
不幸的是,我在将其实现到Angular应用程序时遇到了一些问题。当我调用下面的函数时,由于无法打开,因此我得到的是“损坏”文件。我已经检查了与我的问题有关的其他问题/解决方案,但是尝试了大多数问题/解决方案后,我再也无法解决问题。
我的服务中的通话
DownloadFile (companyId: string, fileId: string, extension: string, fileName: string): Observable<Blob> {
const options = { responseType: 'blob' as 'json' }
return this.http.get<Blob>(this.baseApiUrl + this.baseTag + "?companyId=" + companyId + "&fileId=" + fileId + "&extension=" + extension + "&fileName=" + fileName, options)
}
使用服务调用:
this.data.DownloadFile(this.company.id, selectedItem.id, this.getFileNameWithoutExtension(selectedItem.fileName), this.getExtensionFromFileName(selectedItem.fileName))
.subscribe(resultBlob =>
{
//Success
console.log('start download:', resultBlob);
var blob = new Blob([resultBlob], { type: "application/pdf" } );
saveAs(blob, selectedItem.fileName);
},
error => {
//Error
console.log(error);
});
我希望有人能帮助我,因为我没有看到这段代码的问题。
答案 0 :(得分:2)
在DownloadFile()
中,参数为:
companyId, fileId, extension, fileName
但是当您调用该服务时,您似乎已经将文件名和扩展名参数翻转为:
companyId, fileId, fileName, extension
容易犯的错误。 :)
快乐的编码。