Autorizzazione READ_EXTERNAL_STORAGE per Android

Sto cercando di accedere ai file multimediali (musica) sul dispositivo utente per riprodurli; un facile "hello world" -music player app.

Ho seguito alcuni tutorial e fondamentalmente danno lo stesso codice. Ma non functionrà; continua a schiantarmi e mi dice:

  • Come posso implementare la barra degli strumenti personalizzata con pulsanti personalizzati in Android?
  • Come get l'istanza di frammento dalla FragmentActivity?
  • Come fermare l'intenti di assistenza in android?
  • Come rilevare in Android se UID dal tag NFC è random?
  • Ricco di immagini scorrere e zoom su android
  • Utilizzo di jcodec SequenceEncoder
  • error..... Caused by: java.lang.SecurityException: Permission Denial: reading com.android.providers.media.MediaProvider uri content://media/external/audio/media from pid=27696, uid=10059 requires android.permission.READ_EXTERNAL_STORAGE, or grantUriPermission() .... 

    Ora, questo è il mio file manifesto:

     <?xml version="1.0" encoding="utf-8"?> <manifest xmlns:android="http://schemas.android.com/apk/res/android" package="slimsimapps.troff" > <uses-permission android:name="android.permission.MEDIA_CONTENT_CONTROL"/> <uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE"/> <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/> <application android:allowBackup="true" android:icon="@mipmap/ic_launcher" android:label="@string/app_name" android:theme="@style/AppTheme" > <activity android:name=".MainActivity" android:label="@string/app_name" > <intent-filter> <action android:name="android.intent.action.MAIN" /> <category android:name="android.intent.category.LAUNCHER" /> </intent-filter> </activity> </application> </manifest> 

    Questo è il mio metodo Java:

     public void initialize() { ContentResolver contentResolver = getContentResolver(); Uri uri = MediaStore.Audio.Media.EXTERNAL_CONTENT_URI; Cursor cursor = contentResolver.query(uri, null, null, null, null); if (cursor == null) { // query failed, handle error. } else if (!cursor.moveToFirst()) { // no media on the device } else { do { addSongToXML(cursor); } while (cursor.moveToNext()); } } 

    Ho provato:

    Per metterlo in luoghi diversi nel file manifesto:

     <uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE”/> 

    Per aggiungere android: maxSdkVersion a Leggi la logging esterna di archiviazione:

     <uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE" android:maxSdkVersion="21" /> 

    Per metterlo nel tag manifesto / applicazione / attività:

     android:exported=“true” 

    Per mettere grantUriPremission tra uri e cursro nel javamethod:

     grantUriPermission(null, uri, Intent.FLAG_GRANT_READ_URI_PERMISSION); 

    Per utilizzare questo, non si blocca, ma il cursore diventa nullo:

     uri = MediaStore.Audio.Media.getContentUri("EXTERNAL_CONTENT_URI”); 

    Per utilizzare il contenuto INTERNO uri, questo funziona come previsto, ma fornisce solo "suoni OS" come il suono dell'otturatore, il basso livello di batteria, il button di scatto e simili:

     uri = MediaStore.Audio.Media.INTERNAL_CONTENT_URI; 

    Mi piace aiutare, questo non dovrebbe essere un problema difficile lo so, ma mi sento come un principiante!

    Ho letto e provato (o li ho considerati non applicabili per il mio problema):

    • L'authorization di Android READ_EXTERNAL_STORAGE non funziona
    • Richiedere l'authorization solo per versioni precedenti Android: maxSdkVersion non funziona?
    • Ottieni il nome di file e il path da URI dal mediastore
    • Android KitKat securityException quando si cerca di leggere da MediaStore
    • Android: java.lang.SecurityException: Denial of Permission: start Intent

    Stack trace:

     09-08 06:59:36.619 2009-2009/slimsimapps.troff D/AndroidRuntime﹕ Shutting down VM --------- beginning of crash 09-08 06:59:36.619 2009-2009/slimsimapps.troff E/AndroidRuntime﹕ FATAL EXCEPTION: main Process: slimsimapps.troff, PID: 2009 java.lang.IllegalStateException: Could not execute method for android:onClick at android.view.View$DeclaredOnClickListener.onClick(View.java:4452) at android.view.View.performClick(View.java:5198) at android.view.View$PerformClick.run(View.java:21147) at android.os.Handler.handleCallback(Handler.java:739) at android.os.Handler.dispatchMessage(Handler.java:95) at android.os.Looper.loop(Looper.java:148) at android.app.ActivityThread.main(ActivityThread.java:5417) at java.lang.reflect.Method.invoke(Native Method) at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:726) at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:616) Caused by: java.lang.reflect.InvocationTargetException at java.lang.reflect.Method.invoke(Native Method) at android.view.View$DeclaredOnClickListener.onClick(View.java:4447)            at android.view.View.performClick(View.java:5198)            at android.view.View$PerformClick.run(View.java:21147)            at android.os.Handler.handleCallback(Handler.java:739)            at android.os.Handler.dispatchMessage(Handler.java:95)            at android.os.Looper.loop(Looper.java:148)            at android.app.ActivityThread.main(ActivityThread.java:5417)            at java.lang.reflect.Method.invoke(Native Method)            at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:726)            at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:616) Caused by: java.lang.SecurityException: Permission Denial: reading com.android.providers.media.MediaProvider uri content://media/external/audio/media from pid=2009, uid=10059 requires android.permission.READ_EXTERNAL_STORAGE, or grantUriPermission() at android.os.Parcel.readException(Parcel.java:1599) at android.database.DatabaseUtils.readExceptionFromParcel(DatabaseUtils.java:183) at android.database.DatabaseUtils.readExceptionFromParcel(DatabaseUtils.java:135) at android.content.ContentProviderProxy.query(ContentProviderNative.java:421) at android.content.ContentResolver.query(ContentResolver.java:491) at android.content.ContentResolver.query(ContentResolver.java:434) at slimsimapps.troff.MainActivity.initialize(MainActivity.java:106) at slimsimapps.troff.MainActivity.InitializeExternal(MainActivity.java:80)            at java.lang.reflect.Method.invoke(Native Method)            at android.view.View$DeclaredOnClickListener.onClick(View.java:4447)            at android.view.View.performClick(View.java:5198)            at android.view.View$PerformClick.run(View.java:21147)            at android.os.Handler.handleCallback(Handler.java:739)            at android.os.Handler.dispatchMessage(Handler.java:95)            at android.os.Looper.loop(Looper.java:148)            at android.app.ActivityThread.main(ActivityThread.java:5417)            at java.lang.reflect.Method.invoke(Native Method)            at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:726)            at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:616) --------- beginning of system 

  • Qualsiasi modo per cambiare il colore di un button di scelta rapida?
  • Come registrare un nuovo utente su XMPP utilizzando (a) la libreria Smack
  • Condivisione dei dati tra frammenti e attività in Android
  • Ottenere spazio libero sulla memory interna
  • Come trovare l'impronta digitale MD5 della mia applicazione Android
  • Miglior approccio per la vecchia scuola 2D gioco zelda
  • 8 Solutions collect form web for “Autorizzazione READ_EXTERNAL_STORAGE per Android”

    Hai due soluzioni per il tuo problema. Il più veloce è quello di abbassare il targetApi a 22 (build.gradle file). Secondo è quello di utilizzare un nuovo e meraviglioso model di domanda-permesso:

     if (checkSelfPermission(Manifest.permission.READ_EXTERNAL_STORAGE) != PackageManager.PERMISSION_GRANTED) { // Should we show an explanation? if (shouldShowRequestPermissionRationale( Manifest.permission.READ_EXTERNAL_STORAGE)) { // Explain to the user why we need to read the contacts } requestPermissions(new String[]{Manifest.permission.READ_EXTERNAL_STORAGE}, MY_PERMISSIONS_REQUEST_READ_EXTERNAL_STORAGE); // MY_PERMISSIONS_REQUEST_READ_EXTERNAL_STORAGE is an // app-defined int constant that should be quite unique return; } 

    Sniplet trovato qui: https://developer.android.com/training/permissions/requesting.html

    Hai richiesto l'authorization all'ora di esecuzione:

     if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.M && ContextCompat.checkSelfPermission(this, Manifest.permission.READ_EXTERNAL_STORAGE) != PackageManager.PERMISSION_GRANTED) { ActivityCompat.requestPermissions(this, new String[]{Manifest.permission.READ_EXTERNAL_STORAGE}, REQUEST_PERMISSION); dialog.dismiss(); return; } 

    E nel richiamo di seguito puoi accedere alla memory senza alcun problema.

     @Override public void onRequestPermissionsResult(final int requestCode, @NonNull final String[] permissions, @NonNull final int[] grantResults) { super.onRequestPermissionsResult(requestCode, permissions, grantResults); if (requestCode == REQUEST_PERMISSION) { if (grantResults.length > 0 && grantResults[0] == PackageManager.PERMISSION_GRANTED) { // Permission granted. } else { // User refused to grant permission. } } } 

    Il problema è stato risolto? Qual è il tuo target SDK? Prova ad aggiungere android;maxSDKVersion="21" a <uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE" />

    Ho avuto anche un log di errore simile e qui è quello che ho fatto –

    1. Nel metodo onCreate abbiamo richiesto una window di dialogo per controllare le autorizzazioni

       ActivityCompat.requestPermissions(MainActivity.this, new String[]{Manifest.permission.READ_EXTERNAL_STORAGE},1); 
    2. Metodo per verificare il risultato

       @Override public void onRequestPermissionsResult(int requestCode, String permissions[], int[] grantResults) { switch (requestCode) { case 1: { // If request is cancelled, the result arrayss are empty. if (grantResults.length > 0 && grantResults[0] == PackageManager.PERMISSION_GRANTED) { // permission granted and now can proceed mymethod(); //a sample method called } else { // permission denied, boo! Disable the // functionality that depends on this permission. Toast.makeText(MainActivity.this, "Permission denied to read your External storage", Toast.LENGTH_SHORT).show(); } return; } // add other cases for more permissions } } 

    La documentazione ufficiale a Requesting Permissions Runtime

    Fase 1: aggiungere l'authorization su android manifest.xml

     <uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE" /> <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/> 

    Passaggio2: metodo onCreate ()

     int permissionCheck = ContextCompat.checkSelfPermission(this, Manifest.permission.WRITE_EXTERNAL_STORAGE); if (permissionCheck != PackageManager.PERMISSION_GRANTED) { ActivityCompat.requestPermissions(this, new String[]{Manifest.permission.WRITE_EXTERNAL_STORAGE}, MY_PERMISSIONS_REQUEST_READ_MEDIA); } else { readDataExternal(); } 

    Fase 3: sovrascrivere il metodo onRequestPermissionsResult per get il richiamo

      @Override public void onRequestPermissionsResult(int requestCode, String permissions[], int[] grantResults) { switch (requestCode) { case MY_PERMISSIONS_REQUEST_READ_MEDIA: if ((grantResults.length > 0) && (grantResults[0] == PackageManager.PERMISSION_GRANTED)) { readDataExternal(); } break; default: break; } } 

    Nota: readDataExternal () è il metodo per get i dati dalla memory esterna.

    Grazie.

    http://developer.android.com/reference/android/provider/MediaStore.Audio.AudioColumns.html

    Prova a cambiare la row contentResolver.query

     //change it to the columns you need String[] columns = new String[]{MediaStore.Audio.AudioColumns.DATA}; Cursor cursor = contentResolver.query(uri, columns, null, null, null); 

    pubblica statica finale String MEDIA_CONTENT_CONTROL

    Non per uso da parte di applicazioni di terze parti a causa della riservatezza dei consumi multimediali

    http://developer.android.com/reference/android/Manifest.permission.html#MEDIA_CONTENT_CONTROL

    cercare di rimuovere prima il <uses-permission android:name="android.permission.MEDIA_CONTENT_CONTROL"/> e riprovare?

    Controlla sotto il codice che usa che puoi trovare tutti i file musicali da sdcard:

     public class MainActivity extends Activity{ @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_animations); getAllSongsFromSDCARD(); } public void getAllSongsFromSDCARD() { String[] STAR = { "*" }; Cursor cursor; Uri allsongsuri = MediaStore.Audio.Media.EXTERNAL_CONTENT_URI; String selection = MediaStore.Audio.Media.IS_MUSIC + " != 0"; cursor = managedQuery(allsongsuri, STAR, selection, null, null); if (cursor != null) { if (cursor.moveToFirst()) { do { String song_name = cursor .getString(cursor .getColumnIndex(MediaStore.Audio.Media.DISPLAY_NAME)); int song_id = cursor.getInt(cursor .getColumnIndex(MediaStore.Audio.Media._ID)); String fullpath = cursor.getString(cursor .getColumnIndex(MediaStore.Audio.Media.DATA)); String album_name = cursor.getString(cursor .getColumnIndex(MediaStore.Audio.Media.ALBUM)); int album_id = cursor.getInt(cursor .getColumnIndex(MediaStore.Audio.Media.ALBUM_ID)); String artist_name = cursor.getString(cursor .getColumnIndex(MediaStore.Audio.Media.ARTIST)); int artist_id = cursor.getInt(cursor .getColumnIndex(MediaStore.Audio.Media.ARTIST_ID)); System.out.println("sonng name"+fullpath); } while (cursor.moveToNext()); } cursor.close(); } } } 

    Ho aggiunto anche la seguente row nel file AndroidManifest.xml come segue:

     <uses-sdk android:minSdkVersion="16" android:targetSdkVersion="17" /> <uses-permission android:name="android.permission.MEDIA_CONTENT_CONTROL" /> <uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE" /> <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" /> 

    Basta andare alle "impostazioni", sotto "dispositivo" select "applicazioni" e poi scorrere fino alla tua MY_APPLICATION e concedere l'authorization "memorizzazione".

    L'Android è un fan Android di Google, tutto su telefoni Android, Android Wear, Android Dev e applicazioni Android Games e così via.