wake-up-neo.com

READ_EXTERNAL_STORAGE-Berechtigung für Android

Ich versuche, auf Mediendateien (Musik) auf dem Benutzergerät zuzugreifen, um sie abzuspielen. eine einfache "Hallo Welt" -Musik-Player-App.

Ich habe einige Tutorials befolgt und sie geben im Grunde den gleichen Code. Aber es wird nicht funktionieren. es stürzt immer wieder ab und sagt mir:

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()
....

Dies ist meine Manifest-Datei:

<?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>

Das ist meine Java-Methode:

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());
    }
}

Ich habe versucht:

So platzieren Sie dies an verschiedenen Stellen in der Manifestdatei:

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

So fügen Sie Android hinzu: maxSdkVersion at Externen Speicher lesen premission:

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

So fügen Sie dies in das Manifest/application/activity-tag ein:

Android:exported=“true”

So setzen Sie grantUriPremission zwischen uri und cursro in die Javamethode:

grantUriPermission(null, uri, Intent.FLAG_GRANT_READ_URI_PERMISSION);

Um dies zu verwenden, stürzt es nicht ab, aber der Cursor wird zu null:

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

Um INTERNAL content uri zu verwenden, funktioniert dies wie erwartet, es werden jedoch nur "OS-Sounds" wie Shutter-Sound, Low-Battery-Sound, Button-Click usw. ausgegeben:

uri = MediaStore.Audio.Media.INTERNAL_CONTENT_URI;

Bitte helfen Sie, dies sollte kein schweres Problem sein, aber ich fühle mich wie ein Anfänger!

Ich habe gelesen und versucht (oder als für mein Problem nicht zutreffend erachtet):

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
70
Slim Sim

Sie haben zwei Lösungen für Ihr Problem. Die schnelle Methode besteht darin, targetApi auf 22 (build.gradle-Datei) zu senken. Das zweite ist die Verwendung eines neuen und wunderbaren Modells, bei dem um Erlaubnis gefragt wird:

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 hier gefunden: https://developer.Android.com/training/permissions/requesting.html

69
piotrpo

Sie haben zur Laufzeit nach der Erlaubnis gefragt:

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;
}

Und im nachfolgenden Callback können Sie problemlos auf den Speicher zugreifen.

@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.
        }
    }
}
14
maclir

Schritt 1: Fügen Sie die Berechtigung für Android manifest.xml hinzu

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

Schritt 2: onCreate () Methode

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();
    }

Schritt 3: Überschreiben Sie die onRequestPermissionsResult-Methode, um den Rückruf abzurufen

 @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;
    }
}

Hinweis: readDataExternal () ist eine Methode zum Abrufen von Daten aus einem externen Speicher.

Vielen Dank.

6
sonnv1368

Ich hatte auch ein ähnliches Fehlerprotokoll und hier ist, was ich getan habe-

  1. Bei der onCreate-Methode fordern wir ein Dialogfeld zum Überprüfen der Berechtigungen an

    ActivityCompat.requestPermissions(MainActivity.this,
    new String[]{Manifest.permission.READ_EXTERNAL_STORAGE},1);
    
  2. Methode zur Überprüfung des Ergebnisses

    @Override
    public void onRequestPermissionsResult(int requestCode, String permissions[], int[] grantResults) {
    switch (requestCode) {
        case 1: {
            // If request is cancelled, the result arrays 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
        }
    }
    

Die offizielle Dokumentation zu Requesting Runtime Permissions

4
user7020107

Wurde Ihr Problem behoben? Was ist Ihr Ziel-SDK? Versuchen Sie, Android;maxSDKVersion="21" bis <uses-permission Android:name="Android.permission.READ_EXTERNAL_STORAGE" />

1
Jerry Ejonavi

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

Versuchen Sie, die Zeile zu ändern 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);

public static final String MEDIA_CONTENT_CONTROL

Aus Datenschutzgründen für den Medienkonsum nicht für Anwendungen von Drittanbietern geeignet

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

versuchen Sie zuerst, den <uses-permission Android:name="Android.permission.MEDIA_CONTENT_CONTROL"/> zu entfernen und versuchen Sie es erneut?

0
Derek Fung

Dazu alle Antworten. Sie können auch das Minsdk angeben, das mit dieser Anmerkung angewendet werden soll

@TargetApi(_apiLevel_)

Ich habe dies benutzt, um diese Anfrage anzunehmen, obwohl mein minsdk 18 ist. Das bedeutet, dass die Methode nur ausgeführt wird, wenn das Gerät auf "_apilevel_" und höher ausgerichtet ist. Hier ist meine Methode:

    @TargetApi(23)
void solicitarPermisos(){

    if (ContextCompat.checkSelfPermission(this,permiso)
            != 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},
                1);

        // MY_PERMISSIONS_REQUEST_READ_EXTERNAL_STORAGE is an
        // app-defined int constant that should be quite unique

        return;
    }

}
0
Gian Gomen

Bitte überprüfen Sie den folgenden Code, mit dem Sie alle Musikdateien von der SD-Karte finden können:

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();
    }
}


}

Ich habe auch die folgende Zeile in die AndroidManifest.xml-Datei eingefügt:

<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" />
0
Rajan Bhavsar