Как отобразить созданный на стороне сервера поток PDF в javascript, отправленный через контент HttpMessageResponse
На моей стороне сервера я использую ASP.NET MVC Web Api, где я создаю PDF файл с помощью отчета Crystal и экспортирую его в формат PDF. Код выглядит следующим образом:
[HttpPost]
public HttpResponseMessage SetReport(string name, [FromBody]List<KontoDto> konta)
{
var response = Request.CreateResponse(HttpStatusCode.OK);
var strReportName = "KontoReport.rpt";
var rd = new ReportDocument();
string strPath = HttpContext.Current.Server.MapPath("~/") + "Reports//" + strReportName;
rd.Load(strPath);
rd.SetDataSource(konta);
var tip = ExportFormatType.PortableDocFormat;
var pdf = rd.ExportToStream(tip);
response.Headers.Clear();
response.Content = new StreamContent(pdf);
response.Content.Headers.ContentType = new MediaTypeHeaderValue("application/pdf");
return response;
}
Мой код Javascript:
$scope.xxprint = function () {
console.log($scope.konta);
$http.post('/api/konto/setReport/pdf', $scope.konta, { responseType: 'arraybuffer' })
.success(function (data) {
var file = new Blob([data], { type: 'application/pdf' });
var fileURL = URL.createObjectURL(file);
window.open(fileURL);
});
};
Это просто не работает. Я не знаю, что случилось с этим кодом. Я получаю браузер, чтобы открыть просмотрщик PDF, но он пуст. Кроме того, созданный pdf правильно создан, так как я могу сохранить его на диск и открыть его с помощью программы просмотра Adobe Acrobat. Содержимое HttpResponseMessage также выглядит правильно с помощью Fiddler. См. Изображение:
![enter image description here]()
Ответы
Ответ 1
Кажется, я делал это правильно все время. Проблема была в моей версии angularjs (v1.08). При обновлении до версии 1.2 все работало нормально. В версии 1.0 параметр responseType: 'arraybuffer'
(который имеет решающее значение для того, что я делал) просто игнорировался angularjs. Кажется, что он реализован по версии 1.1. См. Этот вопрос SO: Как читать двоичные данные в AngularJS в ArrayBuffer?
Ответ 2
Эта ссылка очень помогла нам. Решение ниже помогло мне.
В нашем случае OFF LINE хранится в потоке в БД:
//Reading the exising pdf file
byte[] bytes = File.ReadAllBytes(pafTemplate);
//gettting memory stream object and writing in to it
var stream = new MemoryStream();
stream.Write(bytes, 0, bytes.Length);
//For our custom need we are placing the memory stream in one of the column
PdfDataTable.PdfFormDataColum = stream.GetBuffer();
Код веб-API:
[GET("api/pdf/getPdfRecordData/{pdfId}")] //AttributeRouting
public HttpResponseMessage GetPdfRecordData(int pdfId)
{
HttpResponseMessage response = Request.CreateResponse(HttpStatusCode.OK, "value");
MemoryStream ms = GetPdfMemoryStreamFromDataBase(pafId);
response.Content = new ByteArrayContent(ms.ToArray());
response.Content.Headers.ContentType = new MediaTypeHeaderValue("application/pdf");
ms.Close();
return response;
}
Код AngularJs:
$http.get('api/pdf/getPdfRecordData/10', null, { responseType: 'arraybuffer' })
.success(function (data) {
var file = new Blob([data], { type: 'application/pdf' });
var fileURL = URL.createObjectURL(file);
window.open(fileURL);
});