Пакет xyz не соответствует uid: 10044 на диске, 10045 в настройках - PullRequest
8 голосов
/ 22 июня 2011

Я нашел простое руководство по установке Android-x86 в ВМ ( руководство ).
Соединение с Eclipse и все работает нормально, но установка моего приложения на виртуальную машину завершается с ошибками:

06-21 22:40:26.390: INFO/PackageManager(2439): /data/app/xyz.apk changed; unpacking
06-21 22:40:26.390: ERROR/PackageManager(2439): Package xyz has mismatched uid: 10044 on disk, 10045 in settings
06-21 22:40:26.390: WARN/PackageManager(2439): Native ABI mismatch from package file
06-21 22:40:26.390: WARN/PackageManager(2439): Package couldn't be installed in /data/app/xyz-1.apk

Я искал ошибку в Google и нашел небольшой скрипт на Python, чтобы исправить проблему, но он не работает ( script ). После выполнения скрипта я получил ту же ошибку.

Я использую универсальный Android-x86 2.2, более подробную информацию можно найти здесь: Выпуск 2.2

Есть ли возможность исправить эту проблему?

EDIT:

Я тестировал все версии 2.2. В общем работают только дженерики и спарта, но никто не принимает мой apk.
Пробовал с adb install <packagefile> тоже.

EDIT2:

Я попробовал рекомендованные инструменты от @Vlad. Работает частично после подписания апк. Наконец, я использовал apkTools и заменил старые файлы apkEdit новыми файлами из apktool.
Но установка с adb зависает с сообщением в ожидании устройства или ничего. Если я верю, что eclipse DDMS соединение с устройством будет потеряно каждый раз, когда я пытаюсь установить apk.
Вот ошибка, когда я пытаюсь установить normal apk: Failure [INSTALL_FAILED_INVALID_APK]

Ответы [ 3 ]

1 голос
/ 15 мая 2016

Ошибка Package xyz has mismatched uid: 10044 on disk, 10045 in settings, вызванная существующей папкой /data/data/xyz/.

В этой папке сообщений существует и владелец другого (10044) от установленного (10045). Это вызвано предыдущей нечистой установкой.

Например, предыдущая установка завершилась с некоторыми ошибками и не удаляет созданные папки.

Потому что в папке могут быть данные из другого приложения, андроид не может разрешить им пользоваться. PackageManager попробуйте исправить это по-разному, но если не можете это сделать - он получит другое приложение и покажет это сообщение.

Лучшее решение - установите приложение и уберите его. После этого установите его снова.

Другое решение - удалить папку /data/data/xyz/ в некоторых отношениях. Может быть вам нужен рут для этого.

Код от PackageManager (комментарии могут быть очень полезными):

            // This is a normal package, need to make its data directory.
        dataPath = getDataPathForPackage(pkg.packageName, 0);

        boolean uidError = false;

        if (dataPath.exists()) {
            // XXX should really do this check for each user.
            mOutPermissions[1] = 0;
            FileUtils.getPermissions(dataPath.getPath(), mOutPermissions);

            // If we have mismatched owners for the data path, we have a problem.
            if (mOutPermissions[1] != pkg.applicationInfo.uid) {
                boolean recovered = false;
                if (mOutPermissions[1] == 0) {
                    // The directory somehow became owned by root.  Wow.
                    // This is probably because the system was stopped while
                    // installd was in the middle of messing with its libs
                    // directory.  Ask installd to fix that.
                    int ret = mInstaller.fixUid(pkgName, pkg.applicationInfo.uid,
                            pkg.applicationInfo.uid);
                    if (ret >= 0) {
                        recovered = true;
                        String msg = "Package " + pkg.packageName
                                + " unexpectedly changed to uid 0; recovered to " +
                                + pkg.applicationInfo.uid;
                        reportSettingsProblem(Log.WARN, msg);
                    }
                }
                if (!recovered && ((parseFlags&PackageParser.PARSE_IS_SYSTEM) != 0
                        || (scanMode&SCAN_BOOTING) != 0)) {
                    // If this is a system app, we can at least delete its
                    // current data so the application will still work.
                    int ret = mInstaller.remove(pkgName, 0);
                    if (ret >= 0) {
                        // TODO: Kill the processes first
                        // Remove the data directories for all users
                        sUserManager.removePackageForAllUsers(pkgName);
                        // Old data gone!
                        String prefix = (parseFlags&PackageParser.PARSE_IS_SYSTEM) != 0
                                ? "System package " : "Third party package ";
                        String msg = prefix + pkg.packageName
                                + " has changed from uid: "
                                + mOutPermissions[1] + " to "
                                + pkg.applicationInfo.uid + "; old data erased";
                        reportSettingsProblem(Log.WARN, msg);
                        recovered = true;

                        // And now re-install the app.
                        ret = mInstaller.install(pkgName, pkg.applicationInfo.uid,
                                pkg.applicationInfo.uid);
                        if (ret == -1) {
                            // Ack should not happen!
                            msg = prefix + pkg.packageName
                                    + " could not have data directory re-created after delete.";
                            reportSettingsProblem(Log.WARN, msg);
                            mLastScanError = PackageManager.INSTALL_FAILED_INSUFFICIENT_STORAGE;
                            return null;
                        }
                        // Create data directories for all users
                        sUserManager.installPackageForAllUsers(pkgName,
                                pkg.applicationInfo.uid);
                    }
                    if (!recovered) {
                        mHasSystemUidErrors = true;
                    }
                } else if (!recovered) {
                    // If we allow this install to proceed, we will be broken.
                    // Abort, abort!
                    mLastScanError = PackageManager.INSTALL_FAILED_UID_CHANGED;
                    return null;
                }
                if (!recovered) {
                    pkg.applicationInfo.dataDir = "/mismatched_uid/settings_"
                        + pkg.applicationInfo.uid + "/fs_"
                        + mOutPermissions[1];
                    pkg.applicationInfo.nativeLibraryDir = pkg.applicationInfo.dataDir;
                    String msg = "Package " + pkg.packageName
                            + " has mismatched uid: "
                            + mOutPermissions[1] + " on disk, "
                            + pkg.applicationInfo.uid + " in settings";
                    // writer
                    synchronized (mPackages) {
                        mSettings.mReadMessages.append(msg);
                        mSettings.mReadMessages.append('\n');
                        uidError = true;
                        if (!pkgSetting.uidError) {
                            reportSettingsProblem(Log.ERROR, msg);
                        }
                    }
                }
            }
            pkg.applicationInfo.dataDir = dataPath.getPath(); 
1 голос
/ 23 июня 2011

Ваше приложение использует собственный код.Вы используете NDK?Один из способов проверить это - использовать «apktool dump badging»

see http://ibotpeaches.github.io/Apktool/

Искать что-то вроде native-code: 'armeabi' в выводе

0 голосов
/ 31 марта 2014

Проблема была связана с программой под названием «dexopt», которая определяет буфер фиксированного размера под названием «LinearAlloc» приложений, установленных на конкретном устройстве.Хотя размер буфера составляет 8 или 16 МБ для новых версий Android, таких как Ice Cream Sandwich и Jelly Bean, в старых версиях он составляет всего 5 МБ.

Когда вы подписываете apk, вы, вероятно, выполняетешаги proguard, которые удаляют части кода, на которые нет ссылок (классы, методы, поля и т. д.). Таким образом, вы передаете эту ошибку, связанную с размером буфера.превышение лимита размера буфера.

У Facebook есть решение для этого: «Разбить наше приложение на несколько файлов dex».Смотри: https://www.facebook.com/notes/facebook-engineering/under-the-hood-dalvik-patch-for-facebook-for-android/10151345597798920

...