很多人和我一样被官网的
ActivityCompat.checkSelfPermission(context, Manifest.permission."XXX XXX XXX") == PackageManager.PERMISSION_GRANTED;获取权限功能忽悠了。这个对于某些权限不适应,比如获取通讯录读写权限等等。这里给出我自己的获取权限方法,很好用的。 话不多说直接上代码: /** * 判断是否拥有联系人读取权限 * * @param context * @return * XXX代表权限字符串,比如 READ_CONTACTS 通讯录读取权限 */ public static boolean havaReadContacts(Context context,String xxx) { boolean have = false; ActivityCompat.checkSelfPermission(context, Manifest.permission.xxx); if (Build.VERSION.SDK_INT >= 23) { AppOpsManager appOpsManager = (AppOpsManager) context.getSystemService(Context.APP_OPS_SERVICE); int checkOp = appOpsManager.checkOp(AppOpsManager.OPSTR_READ_CONTACTS, android.os.Process.myUid(), context.getPackageName()); LogUtil.e(TAG, "checkOp:" + checkOp); switch (checkOp) { case AppOpsManager.MODE_ALLOWED: LogUtil.e(TAG, "AppOpsManager.MODE_ALLOWED :有权限"); have = true; break; case AppOpsManager.MODE_IGNORED: LogUtil.e(TAG, "AppOpsManager.MODE_IGNORED:被禁止了"); have = false; break; case AppOpsManager.MODE_DEFAULT: LogUtil.e(TAG, "AppOpsManager.MODE_DEFAULT"); break; case AppOpsManager.MODE_ERRORED: LogUtil.e(TAG, "AppOpsManager.MODE_ERRORED:出错了"); have = false; break; case 4: LogUtil.e(TAG, "AppOpsManager.OTHER:权限需要询问"); have = false; break; } } else { have = ActivityCompat.checkSelfPermission(context, Manifest.permission.READ_CONTACTS) == PackageManager.PERMISSION_GRANTED; } return have; }