我使用角4作为前端,而内腔5.4作为后端.
我的要求是将一些数据导出为excel和zip文件.
使用’file-saver / FileSaver’中的import {saveAs};包下载文件.
Angular 4代码:
downloadExcel() { const type = 'application/vnd.ms-excel'; const headers = { headers: new Headers({ 'Accept': type }) }; const filename = 'file.xls'; this.http.get('http://10.2.2.109/Download/exportExcel',headers) .toPromise() .then(response => this.saveToFileSystem(response,type,filename)); return false; } private saveToFileSystem(response,__type,filename) { const contentDispositionHeader: string = response.headers.get('Content-Disposition'); if (contentDispositionHeader !== null) { const parts: string[] = contentDispositionHeader.split(';'); //const filename = parts[1].split('=')[1]; const blob = new Blob([response._body],{ type: __type }); saveAs(blob,filename); } else { alert('Cant download.....'); // handling download condition if content disposition is empty const blob = new Blob([response._body],filename); } }
流明代码
public function exportExcel(Request $request) { $file = storage_path(); $file_name = 'book1.xls'; $headers = [ 'Content-type' => 'application/vnd.ms-excel','Content-Disposition' => 'attachment;filename="' . $file_name,'X-Filename' => $file_name,'Content-Transfer-Encoding' => 'binary','Content-Length' => filesize($file . '/' . $file_name),'Cache-Control' => 'max-age=0','Cache-Control' => 'max-age=1','Expires' => 'Mon,26 Jul 1997 05:00:00 GMT','Last-Modified' => gmdate('D,d M Y H:i:s') . ' GMT','Cache-Control' => 'cache,must-revalidate','Pragma' => 'public','Set-Cookie' => 'fileDownload=true; path=/','Access-Control-Expose-Headers' => 'Content-Length,Cache-Control,Content-Language,Content-Type,Expires,Last-Modified,Pragma' ]; return response()->download($file . '/' . $file_name,$file_name,$headers); }
问题
> const contentDispositionHeader:string = response.headers.get(‘Content-Disposition’);似乎总是空的.
>我们无法打开下载的文件,显示已损坏的邮件.
>它适用于文本文件下载
尝试这个:
downloadExcel() { const type = 'application/vnd.ms-excel'; const filename = 'file.xls'; const options = new RequestOptions({ responseType: ResponseContentType.Blob,headers: new Headers({ 'Accept': type }) }); this.http.get('http://10.2.2.109/Download/exportExcel',options) .catch(errorResponse => Observable.throw(errorResponse.json())) .map((response) => { if (response instanceof Response) { return response.blob(); } return response; }) .subscribe(data => saveAs(data,filename),error => console.log(error)); // implement your error handling here }
关键点是responseType:RequestOptions上的ResponseContentType.Blob和返回响应时的response.blob().
一般来说,不建议像这样访问响应的_body属性:response._body,而是应该调用相关的方法来根据其类型获取正文内容(如response.blob(),response.json( )等)