角4を後端、内腔5.4を後端として使用しています。エクセル/ Zipファイルを角4でダウンロードするには
私の要件は、一部のデータをExcelとZIPファイルとしてエクスポートすることです。
インポートを使用する{ saveAs }
'file-saver/FileSaver';
パッケージからファイルをダウンロードします。
角度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], { type: __type });
saveAs(blob, 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');
は常に空と思われます。- ダウンロードしたファイルを開くことができません。破損したメッセージが表示されます。
- テキストファイルのダウンロード
のために働くことは、この問題を解決するために私を助けてください。または他の作業コードを指定する//
ありがとうございました:) さらにもう1つの疑問、サービスを変更してjsonデータとBLOBデータの両方にアクセスする方法。 認証に失敗した場合、または生成できなかった場合は、jsonが返されます。その状態では、blobとjsonデータを処理するために応答型にアクセスするためにサービスをどのように変更できますか? –
可能な解決策については、最新のコードサンプルを参照してください。私は任意のHTTPエラー応答(したがって、基本的にHTTPエラーコード> 400)をキャッチするキャッチ演算子を追加し、そのコンテンツで新しいObservableを作成して、応答からjsonを抽出します。次に、マップ内で、入力がBlob(ハッピーケース)を抽出するためのレスポンスのインスタンスか、コンテンツを単に渡す(エラーケース)かどうかをチェックする必要があります。これはテストされていないことを覚えておいてください。しかし、少なくともそれはあなたに私が望むいくつかのアイデアを与える必要があります:) –
ブロブのデータを除いて、ステータスコード200のjsonデータを返す他のすべての条件を扱います。 –