FATAL EXCEPTION: main
03-27 17:43:08.012: E/AndroidRuntime(18523): Process: com.mtq.freighthelper, PID: 18523
03-27 17:43:08.012: E/AndroidRuntime(18523): java.lang.SecurityException: Permission Denial: starting Intent { act=android.intent.action.CALL dat=tel:xxxx-xxxxxxxx cmp=com.android.server.telecom/.components.UserCallActivity } from ProcessRecord{1f529f5 18523:com.mtq.freighthelper/u0a491} (pid=18523, uid=10491) with revoked permission android.permission.CALL_PHONE
03-27 17:43:08.012: E/AndroidRuntime(18523): at android.os.Parcel.readException(Parcel.java:1620)
03-27 17:43:08.012: E/AndroidRuntime(18523): at android.os.Parcel.readException(Parcel.java:1573)
03-27 17:43:08.012: E/AndroidRuntime(18523): at android.app.ActivityManagerProxy.startActivity(ActivityManagerNative.java:2681)
03-27 17:43:08.012: E/AndroidRuntime(18523): at android.app.Instrumentation.execStartActivity(Instrumentation.java:1509)
03-27 17:43:08.012: E/AndroidRuntime(18523): at android.app.Activity.startActivityForResult(Activity.java:3978)
03-27 17:43:08.012: E/AndroidRuntime(18523): at android.app.Activity.startActivityForResult(Activity.java:3939)
03-27 17:43:08.012: E/AndroidRuntime(18523): at android.app.Activity.startActivity(Activity.java:4262)
03-27 17:43:08.012: E/AndroidRuntime(18523): at android.app.Activity.startActivity(Activity.java:4230)
03-27 17:43:08.012: E/AndroidRuntime(18523): at com.mtq.freighthelper.ui.activity.contacts.ContactsDetailActivity.onClick(ContactsDetailActivity.java:97)
03-27 17:43:08.012: E/AndroidRuntime(18523): at android.view.View.performClick(View.java:5207)
03-27 17:43:08.012: E/AndroidRuntime(18523): at android.view.View$PerformClick.run(View.java:21177)
03-27 17:43:08.012: E/AndroidRuntime(18523): at android.os.Handler.handleCallback(Handler.java:739)
03-27 17:43:08.012: E/AndroidRuntime(18523): at android.os.Handler.dispatchMessage(Handler.java:95)
03-27 17:43:08.012: E/AndroidRuntime(18523): at android.os.Looper.loop(Looper.java:148)
03-27 17:43:08.012: E/AndroidRuntime(18523): at android.app.ActivityThread.main(ActivityThread.java:5438)
03-27 17:43:08.012: E/AndroidRuntime(18523): at java.lang.reflect.Method.invoke(Native Method)
03-27 17:43:08.012: E/AndroidRuntime(18523): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:739)
03-27 17:43:08.012: E/AndroidRuntime(18523): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:629)
使用设备:小米4
android: 6.0
程序报java.lang.SecurityException: Permission Denial: starting Intent { act=android.intent.action.CALL dat=tel:xxxx-xxxxxxxx cmp=com.android.server.telecom/.components.UserCallActivity } from ProcessRecord{1f529f5 18523:com.mtq.freighthelper/u0a491} (pid=18523, uid=10491) with revoked permission
原因:
在6.0 系统中请求某些权限需要检查权限
1 if (!TextUtils.isEmpty(phone)) {2 if (!hasPermission()) {3 //在6.0 系统中请求某些权限需要检查权限
4 int curApiVersion =Build.VERSION.SDK_INT;5 if (curApiVersion >=Build.VERSION_CODES.M) {6 //动态请求拨打电话权限
7 requestPermissions(8 newString[] { Manifest.permission.CALL_PHONE },9 0x11);10 } else{11 intentToCall(phone);12 }13 } else{14 intentToCall(phone);15 }16 }
1 privateboolean hasPermission() {2 if (checkSelfPermission(Manifest.permission.CALL_PHONE) !=PackageManager.PERMISSION_GRANTED) {3 return false;4 }5 return true;6 }7
8 private voidintentToCall(String phoneNumber) {9 Intent intent = newIntent(Intent.ACTION_CALL);10 Uri data = Uri.parse("tel:" +phoneNumber);11 intent.setData(data);12 startActivity(intent);13 }14
15
16 /**17 * 动态请求拨打电话权限后,监听用户的点击事件18 */
19 @Override20 public void onRequestPermissionsResult(intrequestCode,21 String[] permissions, int[] grantResults) {22 super.onRequestPermissionsResult(requestCode, permissions, grantResults);23 if (requestCode == 0x11) {24 //If request is cancelled, the result arrays are empty.
25 if (grantResults.length > 0
26 && grantResults[0] ==PackageManager.PERMISSION_GRANTED) {27 CldLog.i("CMCC", "权限被允许");28 String phone =mContactsInfo.getPhone();29 intentToCall(phone);30 } else{31 CldLog.i("CMCC", "权限被拒绝");32 }33 }34 }
原文:http://www.cnblogs.com/zhaoqingyue/p/6628224.html