Android权限申请----项目必备系列

随着Android6.0的发布,也带来了一些变革,说的就是在Android6.0里面运行时权限的处理,也就是SDK>=23的时候

在运行关于权限时
在旧的权限管理系统-中,权限仅仅在应用程序安装时询问用户一次,用户同意了这些权限应用才能被安装(某些深度定制系统另说),应用程序一旦安装后一些不良厂商就可以可以偷偷的做一些不为人知的事情了,获取用户信息,对用户手机有很多危害。

同时谷歌也意识到这个问题所以在在Android6.0开始,应用程序可以直接安装,应用程序在运行时一个一个询问用户授予权限,系统会弹出一个对话框让用户选择是否授权某个权限给应用程序(这个对话框不能由开发者定制),当应用程序需要用户授予不恰当的权限的时候,用户可以拒绝,用户也可以在设置页面对每个应用程序的权限进行管理。

需要特别注意:这个对话框不是开发者调用某个权限的功能时由系统自动弹出,而是需要开发者手动调用,如果直接调用而没有去申请权限的话,将会导致应用程序崩溃,是相关功能没有响应的权限。

动态权限总共有三个方法:

ContextCompat.checkSelfPermission() 检查权限是否已经授权

ActivityCompat.requestPermissions()动态申请权限,并弹出对话框。

onRequestPermissionsResult()在activity里面重写该方法该方法是权限申请之后的回调方法。

当然。动态权限申请也要在AndroidManifest.xml里面写明。附上代码
public class MainActivity extends AppCompatActivity {
 
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
 
        applypermission();//启动检查权限
    }
 
    //检查权限
    public void applypermission(){
        if(Build.VERSION.SDK_INT>=23){
            //检查是否已经给了权限
            int checkpermission= ContextCompat.checkSelfPermission(getApplicationContext(),
                    Manifest.permission.ACCESS_FINE_LOCATION);
            if(checkpermission!=PackageManager.PERMISSION_GRANTED){//没有给权限
                Log.e("permission","动态申请");
                //参数分别是当前活动,权限字符串数组,requestcode,调取的CAMERA权限
                ActivityCompat.requestPermissions(MainActivity.this,new String[]{Manifest.permission.CAMERA}, 1);
            }
        }
    }
 
    @Override
    public void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions, @NonNull int[] grantResults) {
        super.onRequestPermissionsResult(requestCode, permissions, grantResults);
        //grantResults数组与权限字符串数组对应,里面存放权限申请结果
        if(grantResults[0]== PackageManager.PERMISSION_GRANTED){
            Toast.makeText(MainActivity.this,"CAMERA已授权",Toast.LENGTH_SHORT).show();
        }else{
            Toast.makeText(MainActivity.this,"拒绝授权CAMERA",Toast.LENGTH_SHORT).show();
        }
    }
}

上面是申请单个权限,如果有多项权限需要动态申请。那么只需要把权限写入permission数组即可。下面也给出修改后的代码;

public class MainActivity extends AppCompatActivity {
    //权限数组
    String[] allpermissions=new String[]{Manifest.permission.ACCESS_FINE_LOCATION,
    Manifest.permission.CALL_PHONE};
 
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        //启动权限检查
        applypermission();
    }
    //权限检查
    public void applypermission(){
        if(Build.VERSION.SDK_INT>=23){
            boolean needapply=false;
            for(int i=0;i<allpermissions.length;i++){
                int chechpermission= ContextCompat.checkSelfPermission(getApplicationContext(),
                        allpermissions[i]);
                if(chechpermission!=PackageManager.PERMISSION_GRANTED){
                    needapply=true;
                }
            }
            if(needapply){
                ActivityCompat.requestPermissions(MainActivity.this,allpermissions,1);
            }
        }
    }
 
    @Override
    public void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions, @NonNull int[] grantResults) {
        super.onRequestPermissionsResult(requestCode, permissions, grantResults);
        //for检查相关权限是否授权
        for(int i=0;i<grantResults.length;i++){
            if(grantResults[i]==PackageManager.PERMISSION_GRANTED){
                Toast.makeText(MainActivity.this, permissions[i]+"已授权",Toast.LENGTH_SHORT).show();
            }
            else {
                Toast.makeText(MainActivity.this,permissions[i]+"拒绝授权",Toast.LENGTH_SHORT).show();
            }
        }
    }
}

如果用户拒绝了相关权限;

我们需要检查一下权限:

 

//检查是否已经给了权限
            int checkpermission= ContextCompat.checkSelfPermission(getApplicationContext(),
                    Manifest.permission.ACCESS_FINE_LOCATION);

下面我给出相关需要动态申请的九组权限:

group:android.permission-group.CONTACTS
    permission:android.permission.WRITE_CONTACTS
    permission:android.permission.GET_ACCOUNTS    
    permission:android.permission.READ_CONTACTS
  

  group:android.permission-group.PHONE
    permission:android.permission.READ_CALL_LOG
    permission:android.permission.READ_PHONE_STATE 
    permission:android.permission.CALL_PHONE
    permission:android.permission.WRITE_CALL_LOG
    permission:android.permission.USE_SIP
    permission:android.permission.PROCESS_OUTGOING_CALLS
    permission:com.android.voicemail.permission.ADD_VOICEMAIL
  

  group:android.permission-group.CALENDAR
    permission:android.permission.READ_CALENDAR
    permission:android.permission.WRITE_CALENDAR
  

  group:android.permission-group.CAMERA
    permission:android.permission.CAMERA
  

  group:android.permission-group.SENSORS
    permission:android.permission.BODY_SENSORS
  

  group:android.permission-group.LOCATION
    permission:android.permission.ACCESS_FINE_LOCATION
    permission:android.permission.ACCESS_COARSE_LOCATION
  

  group:android.permission-group.STORAGE
    permission:android.permission.READ_EXTERNAL_STORAGE
    permission:android.permission.WRITE_EXTERNAL_STORAGE
  

  group:android.permission-group.MICROPHONE
    permission:android.permission.RECORD_AUDIO
  

  group:android.permission-group.SMS
    permission:android.permission.READ_SMS
    permission:android.permission.RECEIVE_WAP_PUSH
    permission:android.permission.RECEIVE_MMS
    permission:android.permission.RECEIVE_SMS
    permission:android.permission.SEND_SMS
    permission:android.permission.READ_CELL_BROADCASTS

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值