因此,我最初只想访问联系人姓名,并且只在清单中声明了我的许可。那时我的代码工作正常。但是现在我也在尝试访问该联系人号码,这在logcat中为我提供了以下内容:
2019-11-05 18:56:02.738 30808-30919/? E/DatabaseUtils: Writing exception to parcel
java.lang.SecurityException: Permission Denial: reading com.android.providers.contacts.ContactsProvider2 uri content://com.android.contacts/data/phones from pid=5361,uid=10178 requires android.permission.READ_CONTactS,or granturiPermission()
at android.content.ContentProvider.enforceReadPermissionInner(ContentProvider.java:705)
at android.content.ContentProvider$Transport.enforceReadPermission(ContentProvider.java:565)
at android.content.ContentProvider$Transport.query(ContentProvider.java:224)
at android.content.ContentProviderNative.onTransact(ContentProviderNative.java:112)
at android.os.Binder.execTransact(Binder.java:752)
2019-11-05 18:54:09.212 5113-5113/? E/AndroidRuntime: FATAL EXCEPTION: main
Process: com.example.android.fresh,PID: 5113
java.lang.RuntimeException: Failure delivering result ResultInfo{who=null,request=1,result=-1,data=Intent { dat=content://com.android.contacts/contacts/lookup/2644i1d5681210d9c25a6.1450iSkype_108/738 flg=0x1 }} to activity {com.example.android.fresh/com.example.android.fresh.Mainactivity}: java.lang.SecurityException: Permission Denial: reading com.android.providers.contacts.ContactsProvider2 uri content://com.android.contacts/data/phones from pid=5113,or granturiPermission()
at android.app.activityThread.deliverResults(activityThread.java:4506)
at android.app.activityThread.handleSendResult(activityThread.java:4548)
at android.app.servertransaction.activityResultItem.execute(activityResultItem.java:49)
at android.app.servertransaction.TransactionExecutor.executeCallbacks(TransactionExecutor.java:108)
at android.app.servertransaction.TransactionExecutor.execute(TransactionExecutor.java:68)
at android.app.activityThread$H.handleMessage(activityThread.java:1916)
at android.os.Handler.dispatchMessage(Handler.java:106)
at android.os.Looper.loop(Looper.java:193)
at android.app.activityThread.main(activityThread.java:6898)
at java.lang.reflect.Method.invoke(Native Method)
at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:537)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:858)
Caused by: java.lang.SecurityException: Permission Denial: reading com.android.providers.contacts.ContactsProvider2 uri content://com.android.contacts/data/phones from pid=5113,or granturiPermission()
at android.os.Parcel.createException(Parcel.java:1950)
at android.os.Parcel.readException(Parcel.java:1918)
at android.database.DatabaseUtils.readExceptionFromParcel(DatabaseUtils.java:183)
at android.database.DatabaseUtils.readExceptionFromParcel(DatabaseUtils.java:135)
at android.content.ContentProviderProxy.query(ContentProviderNative.java:432)
at android.content.ContentResolver.query(ContentResolver.java:847)
at android.content.ContentResolver.query(ContentResolver.java:762)
at android.content.ContentResolver.query(ContentResolver.java:720)
at com.example.android.fresh.Mainactivity.getcontactNumber(Mainactivity.java:163)
at com.example.android.fresh.Mainactivity.onactivityResult(Mainactivity.java:129)
at android.app.activity.dispatchactivityResult(activity.java:7476)
at android.app.activityThread.deliverResults(activityThread.java:4499)
at android.app.activityThread.handleSendResult(activityThread.java:4548)
at android.app.servertransaction.activityResultItem.execute(activityResultItem.java:49)
at android.app.servertransaction.TransactionExecutor.executeCallbacks(TransactionExecutor.java:108)
at android.app.servertransaction.TransactionExecutor.execute(TransactionExecutor.java:68)
at android.app.activityThread$H.handleMessage(activityThread.java:1916)
at android.os.Handler.dispatchMessage(Handler.java:106)
at android.os.Looper.loop(Looper.java:193)
at android.app.activityThread.main(activityThread.java:6898)
at java.lang.reflect.Method.invoke(Native Method)
at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:537)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:858)
2019-11-05 18:56:02.740 5361-5361/com.example.android.fresh E/AndroidRuntime: FATAL EXCEPTION: main
Process: com.example.android.fresh,PID: 5361
java.lang.RuntimeException: Failure delivering result ResultInfo{who=null,data=Intent { dat=content://com.android.contacts/contacts/lookup/2644i179d0ece8ca0b7f9.3789r1113-2916221214.1450iSkype_1113.1419r4429-2916221214.847r4510-2916221214/4513 flg=0x1 }} to activity {com.example.android.fresh/com.example.android.fresh.Mainactivity}: java.lang.SecurityException: Permission Denial: reading com.android.providers.contacts.ContactsProvider2 uri content://com.android.contacts/data/phones from pid=5361,or granturiPermission()
at android.app.activityThread.deliverResults(activityThread.java:4506)
at android.app.activityThread.handleSendResult(activityThread.java:4548)
at android.app.servertransaction.activityResultItem.execute(activityResultItem.java:49)
at android.app.servertransaction.TransactionExecutor.executeCallbacks(TransactionExecutor.java:108)
at android.app.servertransaction.TransactionExecutor.execute(TransactionExecutor.java:68)
at android.app.activityThread$H.handleMessage(activityThread.java:1916)
at android.os.Handler.dispatchMessage(Handler.java:106)
at android.os.Looper.loop(Looper.java:193)
at android.app.activityThread.main(activityThread.java:6898)
at java.lang.reflect.Method.invoke(Native Method)
at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:537)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:858)
Caused by: java.lang.SecurityException: Permission Denial: reading com.android.providers.contacts.ContactsProvider2 uri content://com.android.contacts/data/phones from pid=5361,or granturiPermission()
at android.os.Parcel.createException(Parcel.java:1950)
at android.os.Parcel.readException(Parcel.java:1918)
at android.database.DatabaseUtils.readExceptionFromParcel(DatabaseUtils.java:183)
at android.database.DatabaseUtils.readExceptionFromParcel(DatabaseUtils.java:135)
at android.content.ContentProviderProxy.query(ContentProviderNative.java:432)
at android.content.ContentResolver.query(ContentResolver.java:847)
at android.content.ContentResolver.query(ContentResolver.java:762)
at android.content.ContentResolver.query(ContentResolver.java:720)
at com.example.android.fresh.Mainactivity.getcontactNumber(Mainactivity.java:163)
at com.example.android.fresh.Mainactivity.onactivityResult(Mainactivity.java:129)
at android.app.activity.dispatchactivityResult(activity.java:7476)
at android.app.activityThread.deliverResults(activityThread.java:4499)
at android.app.activityThread.handleSendResult(activityThread.java:4548)
at android.app.servertransaction.activityResultItem.execute(activityResultItem.java:49)
at android.app.servertransaction.TransactionExecutor.executeCallbacks(TransactionExecutor.java:108)
at android.app.servertransaction.TransactionExecutor.execute(TransactionExecutor.java:68)
at android.app.activityThread$H.handleMessage(activityThread.java:1916)
at android.os.Handler.dispatchMessage(Handler.java:106)
at android.os.Looper.loop(Looper.java:193)
at android.app.activityThread.main(activityThread.java:6898)
at java.lang.reflect.Method.invoke(Native Method)
at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:537)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:858)
Cursor cur = getcontentResolver().query(uriContact,null,null);
if (cur.moveToFirst()) {
contactName = cur.getString(cur.getcolumnIndex(ContactsContract.Contacts.DISPLAY_NAME));}
Cursor cursorID = getcontentResolver().query(uriContact,new String[]{ContactsContract.Contacts._ID},null);
if (cursorID.moveToFirst()) {
contactID = cursorID.getString(cursorID.getcolumnIndex(ContactsContract.Contacts._ID));
}
cursorID.close();
Log.d(TAG,"Contact ID: " + contactID);
// Using the contact ID now we will get contact phone number
Cursor cursorPhone = getcontentResolver().query(ContactsContract.CommonDataKinds.Phone.CONTENT_URI,new String[]{ContactsContract.CommonDataKinds.Phone.NUMber},ContactsContract.CommonDataKinds.Phone.CONTact_ID + " = ? AND " +
ContactsContract.CommonDataKinds.Phone.TYPE + " = " +
ContactsContract.CommonDataKinds.Phone.TYPE_MOBILE,new String[]{contactID},null);
if (cursorPhone.moveToFirst()) {
contactNumber = cursorPhone.getString(cursorPhone.getcolumnIndex(ContactsContract.CommonDataKinds.Phone.NUMber));
returnval = true;
}
cursorPhone.close();
我该如何解决?