本文参考自郭霖《第一行代码》第2版,本文是学习笔记,供初学者参考。
Android权限机制从第一个版本就是有的,但是早期的这个机制形同虚设,没有安全和隐私可言。
直到Android6.0引入运行时权限这个功能,目的是为了保护用户的安全和隐私。
安卓权限有上百种,分为普通权限和危险权限,对于危险权限,必须由用户手动点击授权才可以。
下面是CALL_PHONE(危险权限)的demo:
public class MainActivity extends AppCompatActivity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
Button makeCall = findViewById(R.id.make_call);
makeCall.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
if(checkSelfPermission(Manifest.permission.CALL_PHONE)
!= PackageManager.PERMISSION_GRANTED){//判断用户是否已经授权,若无授权
requestPermissions(new String[]{Manifest.permission.CALL_PHONE}, 1);
}else{//若已经授权
call();
}
}
});
}
/**
* 跳转到电话页面,拨打10086,使用tel协议
*/
private void call(){
try{
Intent intent = new Intent(Intent.ACTION_CALL);
intent.setData(Uri.parse("tel:10086"));
startActivity(intent);
}catch (SecurityException e){
e.printStackTrace();
}
}
/**
*
* @param requestCode 请求码
* @param permissions 权限数组
* @param grantResults 授权结果
*/
@Override
public void onRequestPermissionsResult(int requestCode,
String[] permissions, int[] grantResults) {
// super.onRequestPermissionsResult(requestCode, permissions, grantResults);
switch (requestCode){
case 1:
if(grantResults.length > 0 && grantResults[0] == PackageManager.PERMISSION_GRANTED){
call();
} else {
Toast.makeText(this, "You denied the permission",
Toast.LENGTH_SHORT).show();
}
break;
default:
break;
}
}
}