Индикатор загрузки загружается и заканчивается, без ошибок и без выходного файла на устройстве - PullRequest
0 голосов
/ 05 сентября 2018

Я создаю сервер загрузки изображений для моего APP с Rest API, в HTML есть две кнопки, одна - кнопка загрузки, а другая - кнопка загрузки. При нажатии на кнопку загрузки индикатор выполнения отображает ход выполнения, но нет выходного файла и не отображает никаких ошибок, даже кнопка загрузки ничего не загружает.

Этот скрипт отлично работает со статическим URL (без API), внося определенные изменения в скрипт.

Ссылка для моего временного Сервера. http://freaksearch.com/aarti/rest-api.php?json=image&Id=

Плагин, необходимый для этого скрипта: cordova-plugin-file-Transfer (это не устаревший плагин) Ссылка для плагина: https://www.npmjs.com/package/cordova-plugin-file-transfer

Вот мой HTML:

<div class="padding">
    <button class="button" ng-click="download()">Download</button>
    <button class="button" ng-click="load()">Load</button>
    {{imgFile}}
    <img ng-src="{{imgFile}}">
</div>

Вот мой сценарий:

$scope.download = function(imageId, imageName) {
    $ionicLoading.show({
      template: 'Downloading...'
    });
    window.requestFileSystem(LocalFileSystem.PERSISTENT, 0, function (fs) {
          fs.root.getDirectory(
              "MyProject",
              {
                create: true
              },
              function (dirEntry) {
                dirEntry.getFile(
                    imageName + ".jpg",
                    {
                      create: true,
                      exclusive: false
                    },
                    function gotFileEntry(fe) {
                      var p = fe.toURL();
                      fe.remove();
                      ft = new FileTransfer();
                      ft.download(
                          encodeURI('http://freaksearch.com/aarti/rest-api?json=image' + imageId),
                          p,
                          function (entry) {
                            $ionicLoading.hide();
                            $scope.imgFile = entry.toURL();
                          },
                          function (error) {
                            $ionicLoading.hide();
                            alert("Download Error Source --> " + error.source);
                          },
                          false,
                          null
                      );
                    },
                    function () {
                      $ionicLoading.hide();
                      console.log("Get the file failed");
                    }
                );
              }
          );
        },
        function () {
          $ionicLoading.hide();
          console.log("Request for filesystem failed");
        });
  }
  $scope.load = function() {
    $ionicLoading.show({
      template: 'Loading...'
    });
    window.requestFileSystem(LocalFileSystem.PERSISTENT, 0, function(fs) {
        fs.root.getDirectory(
            "MyProject",
            {
                create: false
            },
            function(dirEntry) {
                dirEntry.getFile(
                    imageName + ".jpg",
                    {
                        create: false,
                        exclusive: false
                    },
                    function gotFileEntry(fe) {
                        $ionicLoading.hide();
                        $scope.imgFile = fe.toURL();
                    },
                    function(error) {
                        $ionicLoading.hide();
                        console.log("Error getting file");
                    }
                );
            }
        );
    },
    function() {
        $ionicLoading.hide();
        console.log("Error requesting filesystem");
    });
}

1 Ответ

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

Добавление <preference name="AndroidPersistentFileLocation" value="Compatibility" /> в config.xml сделало мою папку и файл видимыми. Я надеюсь, что это может кому-то помочь.

Теперь я могу видеть изображения , но все изображения повреждены .

...