当前位置: 首页 > 面试题库 >

无法加载PDF文档-Angular JS-BLOB

鲜于温书
2023-03-14
问题内容

我正在尝试从Web API获取PDF文档,并希望在AngularApp中显示。出现“无法加载PDF文档错误”。我关注了“AngularJS:在角度应用程序中显示blob(.pdf)”一文。而我可以按照“ 使用AngularJS从ASP.NET WebAPI方法下载文件 ”一文中的说明成功下载同一文件。

看起来我正在将文件获取为“编码的分块传输”。尝试在有角度的应用程序中显示时,某种程度上它没有被解码。请指教。

Web API代码:

HttpResponseMessage result = null;
        var localFilePath = @"C:\Test.pdf";

        if (!File.Exists(localFilePath))
        {
            result = Request.CreateResponse(HttpStatusCode.Gone);
        }
        else
        {// serve the file to the client
            result = Request.CreateResponse(HttpStatusCode.OK);
            result.Content = new StreamContent(new FileStream(localFilePath, FileMode.Open, FileAccess.Read));                
            result.Content.Headers.ContentDisposition = new System.Net.Http.Headers.ContentDispositionHeaderValue("attachment");
            result.Content.Headers.ContentType = new MediaTypeHeaderValue("application/pdf");
            result.Content.Headers.ContentDisposition.FileName = "Test.pdf";
            result.Content.Headers.Add("x-filename", "Test.pdf");
        }

        return result;

角度控制器:

   myModule.controller("pdfviewerController", function ($scope, $http, $log, $sce) {
$http.post('/api/Sample/GetTestFile', {responseType:'arraybuffer'})
 .success(function (response) {      
  var file = new Blob([response], { type: 'application/pdf' });
  var fileURL = URL.createObjectURL(file);
  $scope.content = $sce.trustAsResourceUrl(fileURL);            
 });
});

HTML模板:

<embed ng-src="{{content}}" style="width:200px;height:200px;"></embed>

问题答案:

控制器中有问题。{responseType:'arraybuffer'}非常需要。对于$http.get-它应该是第二个参数。对于$http.post-它应该是第三个参数。

在上述情况下,我正在使用$http.post,并且我已将其{responseType:'arraybuffer'}作为第二个参数传递。

$http.post('/api/Sample/GetTestFile', {responseType:'arraybuffer'})

更正的代码

$http.post('/api/Sample/GetTestFile','', {responseType:'arraybuffer'})



 类似资料:
  • 我一整天都在试着让它发挥作用。现在我可以将文档另存为。docx文件,但我希望能够将文档保存为PDF,我已尝试使用DOMPDF和TCPDF,但不断出现错误“无法加载PDF库”,我确认路径正确。我错过什么了吗?谢谢你的帮助 下面是引发错误的代码 下面是全部错误 致命错误:未捕获异常“PhpOffice\PhpWord\exception\exception”,消息为“无法加载PDF呈现库”/PHPWo

  • 主要内容:加密PDF文档,示例在前一章中,我们已经看到了如何在PDF文档中插入图像。 在本章中,我们将学习如何加密PDF文档。 加密PDF文档 使用和类提供的方法加密PDF文档。 类用于通过为其分配访问权限来保护PDF文档。 使用此教程,您可以限制用户执行以下操作。 打印文档 修改文档的内容 复制或提取文档的内容 添加或修改注释 填写交互式表单域 提取文字和图形以便视障人士使用 汇编文件 打印质量下降 类用于向文档添加基于密码

  • 问题内容: 我正在尝试将CS​​V文件加载到AngularJS中,以便可以对内容进行一些操作。它不是我想要的那样工作。为了测试它是否正确加载,我将其加载到文本区域中以查看内容。 当我加载文件时,它说它已正确加载,但在加载第二个CSV文件之前似乎没有触发onload()事件,在这种情况下,FIRST文件显示在文本区域中。 HTML: JS: 当我将其放入JSFiddle时,该文件根本不会出现在tex

  • 在上一章中,我们已经了解了如何在PDF文档中插入图像。 在本章中,我们将讨论如何加密PDF文档。 加密PDF文档 您可以使用StandardProtectionPolicy和AccessPermission classes提供的方法加密PDF文档。 AccessPermission类用于通过为其分配访问权限来保护PDF文档。 使用此类,您可以限制用户执行以下操作。 打印文档 修改文档的内容 复制或

  • 然而,下载URL与paremeters有一些有趣的地方,它看起来如下所示: (在url中,'&\;‘实际上没有'\',但我把它放在帖子中,以避免将其转义为'&')。 那么这里是什么情况;我是否有3个参数h、e、gd,或者我有一个参数h,其值,或者我有以下3个参数值对:,,(我认为是这样,而且似乎是一个bug)? 为了形成一个正确的http请求,我需要清楚地知道参数、名称和值是什么,但是我有一个令人

  • 问题内容: 我是Angular SPA的新手,这是我第一次通过Googling获取代码并尝试运行。但是我在控制台中遇到一些错误。我不知道为什么,找到了以下控制台错误列表: XMLHttpRequest无法加载文件:/// C:/Users/hp/Downloads/single-page-app-angularjs- master/home.html。跨源请求仅支持以下协议方案:http,数据,c