javascript - 将 image/jpeg 作为 arraybuffer 或 blob 返回

标签 javascript angularjs angularjs-http

我当前正在调用我的 api,它返回一个图像作为 image/jpeg。我的问题是,当通过 javascript Angular .factory 资源调用 url 时,我得到的数组缓冲区为空 {}。另外,字节长度为 0。如果我使用响应类型“”或“文本”调用 api url,我确实会看到多种类型的值。我在这里缺少什么?感谢您的帮助!

JS:

.factory("Img", function($resource) {
    return $resource("http://mypathTo/image/:id", {
      id: "@id"
    }, {
      responseType: '' //arraybuffer return empty
    });
  });

app.controller//代码

    $scope.getImage = function(productid) {
      console.log(productid);
      par = {id: [productid]};
      Img.getImage(par).$promise.then(
        function(data){
          console.log("success:" + data); //I am able to see bytes when coming back as text but not with arraybuffer as data.bytelength = 0
          scope.productionPicturePath = data;
          return data;
        },
        function(data){
          console.log("error" + data);
        }
      );
    }
}

最佳答案

$resource服务只能返回 JavaScript 对象或数组,具体取决于 isArray。获得奇异的物体,例如 ArrayBufferBlob ,使用$http service .

The DEMO

angular.module("app",[])
.controller("ctrl", function($scope,$http) {
    var vm = $scope;
    var url="//i.imgur.com/fHyEMsl.jpg";

    var config = { responseType: 'blob' };
    $http.get(url,config)
      .then(function(response) {
        console.log("OK");
        //console.log(response.data);
        vm.blob = response.data;
        vm.dataURL = URL.createObjectURL(vm.blob);
        console.log(vm.dataURL);
    }).catch(function(response) {
        console.log("ERROR");
        throw response;
    });
})
<script src="//unpkg.com/angular/angular.js"></script>
  <body ng-app="app" ng-controller="ctrl">
      BLOB type {{blob.type}}<br>
      BLOB size {{blob.size}}<br>
    <img ng-src="{{dataURL}}" height="100" />
  </body>

关于javascript - 将 image/jpeg 作为 arraybuffer 或 blob 返回,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47778813/

相关文章:

javascript - 如何使用 AngularJS 以编程方式创建 URL

javascript - 带有嵌套 Promise 的 $q.all 也使用 $q.all 创建

javascript - Angular JS 类型错误 : $http is not a function

javascript - aspx 页面中的 Web 方法未执行

JavaScript 同步两个数组(对象)/查找增量

Javascript + pretty-print JSON

javascript - 如何使用Chart.js 的pluginService 为文本添加颜色?

angularjs - angular.js $ http.post不起作用-没有错误

javascript - 在 Angular js 中使用 jQuery 插件的最佳方法是什么

javascript - AngularJs + php 身份验证