How to display PDF (Blob) on iOS sent from my angularjs app

后端 未结 3 1616
野的像风
野的像风 2020-12-09 06:32

My Angular 1.5 application connect to a Java/Tomcat/Spring backend server via REST.

One REST service generates PDF and send it to the client. It works fine on DEskto

相关标签:
3条回答
  • 2020-12-09 07:18

    Just add the below code as your $http call.I've handled for other browsers as well.

        $http.get("/displayPdf", {responseType: 'arraybuffer', params: {id: 1}}).success(function(data) {
        var blob = new Blob([data], {type 'application/pdf'});
        var anchor = document.createElement("a");
        if(navigator.userAgent.indexOf("Chrome") != -1||navigator.userAgent.indexOf("Opera") != -1){
                        $window.open(URL.createObjectURL(file,{oneTimeOnly:true}));
        }else if(navigator.userAgent.indexOf("iPad") != -1){
                        var fileURL = URL.createObjectURL(file);
                        //var anchor = document.createElement("a");
                        anchor.download="myPDF.pdf";
                        anchor.href = fileURL;
                        anchor.click();
        }else if(navigator.userAgent.indexOf("Firefox") != -1 || navigator.userAgent.indexOf("Safari") != -1){
                            var url = window.URL.createObjectURL(file);
                            anchor.href = url;
                            anchor.download = "myPDF.pdf";
                            document.body.appendChild(anchor);
                            anchor.click();
                            setTimeout(function(){
                                document.body.removeChild(anchor);
                                window.URL.revokeObjectURL(url);  
                            }, 1000);
          }
       });
    
    0 讨论(0)
  • 2020-12-09 07:29

    None of the solutions proposed above did work for me.

    The main issue comes from URL that wasn't retrieved correctly in iOS. The following code do the correct work :

    window.URL = window.URL || window.webkitURL;
    

    Also even with this, it did not work on Chrome iOS, neither Opera iOS...so after digging the internet and inspired with the following questions :

    • Blob createObjectURL download not working in Firefox (but works when debugging)
    • How to open Blob URL on Chrome iOS
    • Display blob (.pdf) in an angular app

    ... I finally ended up with the following code (working on all iOS browsers except FF on iOS) :

    if (window.navigator.msSaveOrOpenBlob) { //IE 11+
      window.navigator.msSaveOrOpenBlob(blob, "my.pdf");
    } else if (userAgent.match('FxiOS')) { //FF iOS
      alert("Cannot display on FF iOS");
    }
    } else if (userAgent.match('CriOS')) { //Chrome iOS
      var reader = new FileReader();
      reader.onloadend = function () { $window.open(reader.result);};
      reader.readAsDataURL(blob);
    } else if (userAgent.match(/iPad/i) || userAgent.match(/iPhone/i)) { //Safari & Opera iOS
      var url = $window.URL.createObjectURL(blob);
      window.location.href = url;
    }
    
    0 讨论(0)
  • 2020-12-09 07:36

    i use basically your same setup but i build my pdf differently using, unable to test with iOS but i hope this helps some

    $http({ url: $scope.url,
                method: "GET",
                headers: { 'Accept': 'application/pdf' },
                responseType: 'arraybuffer' })
            .then(function (response) {
                var file = new Blob([response.data], {type: 'application/pdf'});
                var fileURL = URL.createObjectURL(file);
                $scope.pdfContent = $sce.trustAsResourceUrl(fileURL);
            });//end http
    
    0 讨论(0)
提交回复
热议问题