Angular File Saver в сервисе весеннего отдыха
Я пытаюсь реализовать FileSaver.js, как этот пример, https://github.com/alferov/angular-file-saver чтобы загрузить сгенерированный файл приложением весенней загрузки, у меня есть служба отдыха, которая возвращает файл в виде данных байтового массива.
@RequestMapping(value = "/generateReport/{reportId}/{parameters}",
method = RequestMethod.GET,
produces = MediaType.APPLICATION_JSON_VALUE)
@Timed
public byte[] generateReport(@PathVariable("reportId") String reportId,
@PathVariable("parameters") String parameters
) {
byte[] bFile;
//some code
return bFile;
}
Угловой сервис
'generateReport': {
method: 'GET',
responseType: 'arraybuffer' ,
url: 'adap_report/api/generateReport/:reportId/:parameters',
transformResponse: function (data) {
if (data) {
data = angular.fromJson(data);
}
return data;
}
},
Angularjs контроллер
vm.generateReport = function() {
Report.generateReport({reportId:entity.id,parameters:angular.toJson(vm.parameterList)}, function(result) {
var data = new Blob([result], { type: 'application/octet-stream' });
FileSaver.saveAs(data, 'text.txt');
});
};
Файл заставки работает и файл загружен, но содержимое неверно, я просто получаю файл с этим содержимым
[object Object]
Может ли кто-нибудь помочь мне сохранить сгенерированный файл с угловой библиотекой FileSaver.js?
1 ответ
Решение
Я решил это по http
$http.get('/adap_report/api/generateReport/'+entity.id+'/'+angular.toJson(vm.parameterList), {responseType: 'arraybuffer'})
.success(function (data) {
console.log(data)
if(entity.reportoutputtypecode=="PDF"){
var blobData = new Blob([data], {type: 'application/pdf'});
var fileURL = URL.createObjectURL(blobData);
window.open(fileURL);
}else{
var blobData = new Blob([data], {type: 'application/'+entity.reportoutputtypecode});
FileSaver.saveAs(blobData, 'jasper-file.'+entity.reportoutputtypecode);
}
});