我正在研究Android棉花糖的新权限模型,但我面临着一个我觉得奇怪的问题。
一个带有targetSdkVersion
22的应用程序(所以还没有使用Android Marshmallow的新权限模型)在清单中声明了READ_CONTACTS
权限:
<uses-permission android:name="android.permission.READ_CONTACTS" />
并尝试通过Intent.ACTION_PICK
读取联系人的电话号码
Intent intent = new Intent(Intent.ACTION_PICK);
intent.setType(ContactsContract.CommonDataKinds.Phone.CONTENT_TYPE);
startActivityForResult(intent, PICK_CONTACT_REQUEST);
在装有MRA58K的设备上运行时,在通过ADB安装应用程序后撤销权限后,ContextCompat.checkSelfPermission()
方法仍然返回PERMISSION_GRANTED
,但稍后访问联系人时操作失败,因为返回的游标没有记录。据我所知,这是默认的“回溯兼容性”策略,以避免遗留应用程序崩溃。
@Override
protected void onActivityResult(int requestCode, int resultCode, Intent data) {
if (requestCode == PICK_CONTACT_REQUEST && resultCode == Activity.RESULT_OK) {
Log.i("", "Permission granted: " + (ContextCompat.checkSelfPermission(this, Manifest.permission.READ_CONTACTS) == PackageManager.PERMISSION_GRANTED));
Uri contactUri = data.getData();
Cursor c = null;
try {
c = getContentResolver().query(contactUri, new String[]{ContactsContract.CommonDataKinds.Phone.NUMBER}, null, null, null);
if (c != null && c.moveToFirst()) {
Log.i("", "got phone number: " + c.getString(0));
} else {
Log.w("", "No data received");
}
} catch (Exception e) {
e.printStackTrace();
} finally {
if (c != null) {
c.close();
}
}
} else {
super.onActivityResult(requestCode, resultCode, data);
}
}
在尝试操作之前,如何安全地检测用户是否在权限之前显式地进行了检查?
我还在https://github.com/googlesamples/android-RuntimePermissions上尝试了官方的谷歌样例,将targetSdkVersion
设置为22,结果相同:即使用户撤销了权限,它也会记录权限被授予,然后操作失败。
谢谢;)
https://stackoverflow.com/questions/33039188
复制相似问题