Загрузите файл «отправка файла с именем загрузки» - PullRequest
0 голосов
/ 20 сентября 2018

У меня есть приложение Angular 6, и я хочу загрузить сгенерированный PDF из моего .NET Core API.

Кажется, что каждый из вызовов действителен, но я не уверен, как загрузить / открытьфайл.

Microsoft.AspNetCore.Mvc.Infrastructure.FileContentResultExecutor: Информация: Выполнение Microsoft.AspNetCore.Mvc.FileContentResult, отправка файла с именем загрузки 'test.pdf' ...

API Reporting:

public IActionResult CreateReport()
{
  XtraReport report = m_ReportingManager.GetReport();

  MemoryStream ms = new MemoryStream();
  report.ExportToPdf(ms);

  HttpContext.Response.ContentType = "application/pdf";
  FileContentResult result = new FileContentResult(ms.GetBuffer(), "application/pdf")
  {
    FileDownloadName = "test.pdf"
  };

  return result;
}

И в моем Angular-компоненте у меня 2 вызова службы (1 из SO и 1 сам)

public getReport1() {
    this._reportViewerService.getReport()
      .subscribe(blob => {
        var link = document.createElement('a');
        link.href = window.URL.createObjectURL(blob);
        link.download = "test.pdf";
        link.click();
      }, error => { console.log(error) });
  }

  public getReport2() {   
    this._reportViewerService.getReport().subscribe(
      (result: any) => window.open("http://localhost:44302/Reporting/test.pdf", "_blank"),
      (error: any) => this._loggerService.logError(error),
      () => this.loading = false
    );
  }

А мой сервис выглядит так:

  public getReport(definitionKey: string, reportParameters: ReportParameter[]): Observable<any> {
    const parameters = {
      key: definitionKey,
      reportParameters: reportParameters
    };

    return this._http.post<any>(this.baseUrl + 'CreateReport', parameters);
  }

1 Ответ

0 голосов
/ 20 сентября 2018

Вы можете использовать пакет File Saver для обработки загрузки файла.

https://www.npmjs.com/package/file-saver

Я сделал это в своем приложении, надеюсь, вы сможете адаптировать его к своему:

downloadFile(data: Response){
  let blob = new Blob([data], { type: 'application/pdf' });
  let url= window.URL.createObjectURL(blob);
  console.log(url);
  window.open(url);
}

getPdf() {
   const options: {
        headers?: HttpHeaders,
        observe?: 'body',
        params?: HttpParams,
        reportProgress?: boolean,
        responseType: 'blob',
        withCredentials?: boolean
    } = {
        headers: null,
        params: null,
        responseType: 'blob'
    };

this.http.get(`your api endpoint`, options)
  .subscribe(blob => {
    saveAs(blob, 'file.pdf');
  });
 }
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...