meteor cordova in-app apk更新默默无效

时间:2017-09-01 02:31:12

标签: android cordova meteor fileopener2

我正在尝试实施自动更新功能,以便在常规市场之外分发应用。 我使用了多种cordova插件来下载并执行我的应用程序的更新版本。

我可以看到我将apk下载到外部存储,启动它,允许安装,但没有任何反应(它回到我原来的应用程序)。 apk update steps

我觉得这是一个权限问题,但我在日志中看不到任何内容。 如果我从文件系统打开下载的apk,我可以毫无问题地安装它。 这只是当我从cordova应用程序启动apk时,安装无效。

以下是我用于进行更新的代码:

/**
 * Begin the download and install of the update for android.
 */
update() {
    let _this = this;
    let update = this._updateResult.get();

    // Check permissions first
    let permissions = cordova.plugins.permissions;
    let list = [permissions.WRITE_EXTERNAL_STORAGE];

    let errorPermissions = () => {
        sAlert.error("Cannot update permissions");
    };

    let successPermissions = () => {
        let fileTransfer = new FileTransfer();

        // let targetLocation = cordova.file.externalDataDirectory + "app.apk"; // better use externalCacheDirectory
        let targetLocation = "file:///storage/emulated/0/Download/"+"app-1.4.1.apk";
        console.debug("Begin update in appManager ", update);
        console.info("Download file", update.apk);
        console.info("Download to ", targetLocation);

        let onSuccess = (entry) => {
            let fileURL = entry.toURL();
            console.debug("download complete!", fileURL);

            cordova.plugins.fileOpener2.open(
                fileURL,
                'application/vnd.android.package-archive',
                {
                    error: function (e) {
                        console.log('Error status: ' + e.status + ' - Error message: ' + e.message);
                        _this._updating.set(false);
                    },
                    success: function () {
                        console.log('file opened successfully');
                        _this._updating.set(false);
                    }
                }
            );
        }
        let onError = (error) => {
            _this._updating.set(false);
            console.log("download error source " + error.source);
            console.log("download error target " + error.target);
            console.log("download error code" + error.code);
        }
        let options = {
            chunkedMode: true,
            mimeType: "application/vnd.android.package-archive"
        };

        fileTransfer.download(
            encodeURI(update.apk),
            targetLocation,
            onSuccess,
            onError,
            options,
            true // trustAllHosts
        );
        fileTransfer.onprogress = (progressEvent) => {
            if (progressEvent.lengthComputable) {
                let percent = Math.floor((progressEvent.loaded / progressEvent.total) * 100);
                _this._updating.set(percent);
            } else {
                _this._updating.set(true);
            }
        };
    }

    permissions.hasPermission(list,
        function (status) {
            console.debug("permissions status is", status);
            if (status.hasPermission) {
                successPermissions();
            } else {
                permissions.requestPermissions(
                    list,
                    function (status) {
                        if (!status.hasPermission) {
                            errorPermissions();
                        }
                        successPermissions();
                    },
                    errorPermissions
                );
            }
        }, errorPermissions);
}

我还尝试添加其他权限,如INSTALL_PACKAGES,DELETE_PACKAGES,RESTART_PACKAGES ......

我认为代码中唯一重要的部分应该是

cordova.plugins.fileOpener2.open(
                fileURL,
                'application/vnd.android.package-archive',
                {
                    error: function (e) {
                        console.log('Error status: ' + e.status + ' - Error message: ' + e.message);
                        _this._updating.set(false);
                    },
                    success: function () {
                        console.log('file opened successfully');
                        _this._updating.set(false);
                    }
                }
            );

我的日志显示'文件已成功打开',任何帮助非常感谢:)

1 个答案:

答案 0 :(得分:1)

检查fileopener2插件的代码后,我发现了intent.setFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP);被注释掉了,我尝试添加标志,现在更新工作。