Может ли MediaStore.Audio.Media.DATA указать неверный путь?

Итак, у меня есть такой код:

            String thisPath = cursor.getString(pathColumn);

            MediaMetadataRetriever mmr = new MediaMetadataRetriever();
            mmr.setDataSource(thisPath);

            byte[] data = mmr.getEmbeddedPicture();

            if (data != null) {
                bitmap = BitmapFactory.decodeByteArray(data, 0, data.length);

            } else {
                bitmap = null;
            }

Все работало нормально, пока я не начал получать java.lang.IllegalArgumentException в строке setDataSource(), после некоторого покопания я пришел к выводу, что путь, возвращенный курсором с использованием int pathColumn = cursor.getColumnIndex(MediaStore.Audio.Media.DATA), указывал на файл, которого больше нет в этом месте, я думаю, что это то, что вызывая проблему.

Invalid path: "/storage/emulated/0/zedge/.../Alarm_Clock.mp3"

Я уже установил разрешения на хранилище, и он работает для остальных файлов, которые я ищу, я даже не знаю, как я получаю этот путь, поскольку там нет файла.

Кто-нибудь может помочь?

Ваше здоровье,

Обновлено:

thisPath на самом деле просто строка

String thisPath = musicCursor.getString(pathColumn);

Но здесь инициализируется pathColumn:

ContentResolver contentResolver = getContentResolver();
Uri uri = android.provider.MediaStore.Audio.Media.EXTERNAL_CONTENT_URI;
Cursor cursor = contentResolver.query(uri, null, null, null, null);

    if (cursor != null && cursor.moveToFirst()) {

        int pathColumn = cursor.getColumnIndex(MediaStore.Audio.Media.DATA);

        do {
            String thisPath = cursor.getString(pathColumn);

            MediaMetadataRetriever mmr = new MediaMetadataRetriever();
            mmr.setDataSource(thisPath);

            byte[] data = mmr.getEmbeddedPicture();

            if (data != null) {
                bitmap = BitmapFactory.decodeByteArray(data, 0, data.length);

            } else {
                bitmap = null;
            }

            songList.add(new Song(thisId, thisTitle, thisArtist, thisAlbum, bitmap));

        } while (cursor.moveToNext());

Трассировки стека:

05-15 13:55:50.181 3616-3616/com.bot.lit E/AndroidRuntime: FATAL EXCEPTION: main Process: com.bot.lit, PID: 3616 java.lang.RuntimeException: Unable to start activity ComponentInfo{com.bot.lit/com.bot.lit.MainActivity}: java.lang.IllegalArgumentException at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2606) at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2672) at android.app.ActivityThread.access$1100(ActivityThread.java:180) at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1517) at android.os.Handler.dispatchMessage(Handler.java:111) at android.os.Looper.loop(Looper.java:207) at android.app.ActivityThread.main(ActivityThread.java:5856) at java.lang.reflect.Method.invoke(Native Method) at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:933) at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:782) Caused by: java.lang.IllegalArgumentException at android.media.MediaMetadataRetriever.setDataSource(MediaMetadataRetriever.java:73) at com.bot.lit.MainActivity.getSongList(MainActivity.java:273) at com.bot.lit.MainActivity.onCreate(MainActivity.java:108) at android.app.Activity.performCreate(Activity.java:6347) at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1113) at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2559) at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2672)  at android.app.ActivityThread.access$1100(ActivityThread.java:180)  at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1517)  at android.os.Handler.dispatchMessage(Handler.java:111)  at android.os.Looper.loop(Looper.java:207)  at android.app.ActivityThread.main(ActivityThread.java:5856)  at java.lang.reflect.Method.invoke(Native Method)  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:933)  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:782) `

Не могли бы вы включить полную версию StackTrace и свой код, в котором вы инициализируете thisPath.

Ben 15.05.2018 14:54
In case it might be of help, this image shows the path I'm referring to Боже мой ... удали этот образ. Просто опубликуйте этот путь как текст.
greenapps 15.05.2018 14:58
was pointing to a file that's no longer in that location, I think that's what's causing the issue. Затем сначала проверьте, существует ли файл с помощью File: exists (), и не продолжайте, если это не так.
greenapps 15.05.2018 14:59

Исправлю это, извините @greenapps

b0ttas 15.05.2018 15:11

Добавил то, что вы просили @Ben

b0ttas 15.05.2018 15:12

Был в процессе, ты слишком быстр, товарищ c:

b0ttas 15.05.2018 15:17

почему бы вам просто не использовать setDataSource(String) вместо setDataSource(Context context, Uri uri)?

pskink 16.05.2018 06:56
Пользовательский скаляр GraphQL
Пользовательский скаляр GraphQL
Листовые узлы системы типов GraphQL называются скалярами. Достигнув скалярного типа, невозможно спуститься дальше по иерархии типов. Скалярный тип...
Как вычислять биты и понимать побитовые операторы в Java - объяснение с примерами
Как вычислять биты и понимать побитовые операторы в Java - объяснение с примерами
В компьютерном программировании биты играют важнейшую роль в представлении и манипулировании данными на двоичном уровне. Побитовые операции...
Поднятие тревоги для долго выполняющихся методов в Spring Boot
Поднятие тревоги для долго выполняющихся методов в Spring Boot
Приходилось ли вам сталкиваться с требованиями, в которых вас могли попросить поднять тревогу или выдать ошибку, когда метод Java занимает больше...
Полный курс Java для разработчиков веб-сайтов и приложений
Полный курс Java для разработчиков веб-сайтов и приложений
Получите сертификат Java Web и Application Developer, используя наш курс.
1
7
407
1
Перейти к ответу Данный вопрос помечен как решенный

Ответы 1

Ответ принят как подходящий

I got to the conclusion that the path returned from the cursor using int pathColumn = cursor.getColumnIndex(MediaStore.Audio.Media.DATA) was pointing to a file that's no longer in that location

Это вполне возможно, поскольку индекс MediaStore может быть устаревшим. Также возможно, что DATA указывает на что-то, к чему у вас нет доступа для чтения. Я считаю, что есть сценарии, в которых DATA - это null.

Что ж, я видел здесь вопрос о том, что он возвращает null, не показался мне таким полезным: l Я думал то же самое, после перезагрузки моего телефона он действительно работал нормально, поэтому я полагаю, что индекс каким-то образом обновился, но я не могу действительно считаю это исправлением :)

b0ttas 15.05.2018 15:22

@ b0taSs: «после перезагрузки телефона он действительно работал нормально, поэтому я полагаю, что индекс каким-то образом обновился» - есть крошечная версия робота Google, который периодически сканирует внешнее хранилище и обновляет MediaStore. Это запустится после перезагрузки. «Исправление» состоит в том, что вы не можете предполагать, что DATA полезен.

CommonsWare 15.05.2018 15:30

Другие вопросы по теме