Android开发时,到6.0系统上之后,有的权限就得申请才能用了。

Android将权限分为正常权限 和 危险权限

Android系统权限分为几个保护级别。需要了解的两个最重要保护级别是 正常权限 和 危险权限:

(1)正常权限:

涵盖应用需要访问其沙盒外部数据或资源,但对用户隐私或其他应用操作风险很小的区域。

这些权限在应用安装时授予,运行时不再询问用户。例如: 网络访问、WIFI状态、音量设置等。

(2)危险权限:

涵盖应用需要涉及用户隐私信息的数据或资源,或者可能对用户存储的数据或其他应用的操作产生影响的区域。

例如: 读取通讯录、读写存储器数据、获取用户位置等。如果应用声明需要这些危险权限,则必须在运行时明确告诉用户,让用户手动授予。

 

权限相关知识,权限表请看博客: Android6.0------权限管理

前提:APP运行在Android 6.0 (API level 23)或者更高级别的设备中,而且targetSdkVersion>=23时,系统将会自动采用动态权限管理策略,

先来看看效果图:(注:如果未授权就点击打电话或拍照就会直接闪退,由此6.0必须手动授权,开发时如果未授权,可以判断并提示用户从新授权)

            

 

上图:

1:单个授权,电话授权。

2:有电话,SD卡,拍照授权三个一起授权

 

案例代码:

public class MainActivity extends AppCompatActivity implements View.OnClickListener{     private static final int MY_PERMISSIONS_REQUEST_CALL_PHONE = 1;    private static final int MY_PERMISSIONS_REQUEST_CALL_CAMERA = 2;      String[] permissions = new String[]{            Manifest.permission.CAMERA,            Manifest.permission.WRITE_EXTERNAL_STORAGE,            Manifest.permission.CALL_PHONE    };    // 声明一个集合,在后面的代码中用来存储用户拒绝授权的权    List mPermissionList = new ArrayList<>();      @Override    protected void onCreate(Bundle savedInstanceState) {        super.onCreate(savedInstanceState);        setContentView(R.layout.activity_main);        initView();    }      private void initView(){        findViewById(R.id.btn1).setOnClickListener(this);        findViewById(R.id.btn2).setOnClickListener(this);        findViewById(R.id.btn3).setOnClickListener(this);        findViewById(R.id.btn4).setOnClickListener(this);    }     @Override    public void onClick(View v) {        switch (v.getId()){            case R.id.btn1: //单个授权                //检查版本是否大于M                 if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.M) {                    if (ContextCompat.checkSelfPermission(this, Manifest.permission.CALL_PHONE) != PackageManager.PERMISSION_GRANTED) {                        ActivityCompat.requestPermissions(this,                                new String[]{Manifest.permission.CALL_PHONE},                                MY_PERMISSIONS_REQUEST_CALL_PHONE);                    }else {                        showToast("权限已申请");                    }                }                break;            case R.id.btn2://多个授权                mPermissionList.clear();                for (int i = 0; i < permissions.length; i++) {                    if (ContextCompat.checkSelfPermission(MainActivity.this, permissions[i]) != PackageManager.PERMISSION_GRANTED) {                        mPermissionList.add(permissions[i]);                    }                }                if (mPermissionList.isEmpty()) {//未授予的权限为空,表示都授予了                    Toast.makeText(MainActivity.this,"已经授权",Toast.LENGTH_LONG).show();                } else {//请求权限方法                    String[] permissions = mPermissionList.toArray(new String[mPermissionList.size()]);//将List转为数组                    ActivityCompat.requestPermissions(MainActivity.this, permissions, MY_PERMISSIONS_REQUEST_CALL_CAMERA);                }                break;            case R.id.btn3:                Intent camera = new Intent(MediaStore.ACTION_IMAGE_CAPTURE);                startActivityForResult(camera, 1);                break;            case R.id.btn4:                Intent intent = new Intent(Intent.ACTION_CALL);                Uri data = Uri.parse("tel:" + "10086");                intent.setData(data);                startActivity(intent);                break;        }    }     @Override    public void onRequestPermissionsResult(int requestCode, String[] permissions, int[] grantResults) {         if (requestCode == MY_PERMISSIONS_REQUEST_CALL_PHONE) {            if (grantResults[0] == PackageManager.PERMISSION_GRANTED) {                showToast("权限已申请");            } else {                showToast("权限已拒绝");            }        }else if (requestCode == MY_PERMISSIONS_REQUEST_CALL_CAMERA){                for (int i = 0; i < grantResults.length; i++) {                    if (grantResults[i] != PackageManager.PERMISSION_GRANTED) {                        //判断是否勾选禁止后不再询问                        boolean showRequestPermission = ActivityCompat.shouldShowRequestPermissionRationale(MainActivity.this, permissions[i]);                        if (showRequestPermission) {                            showToast("权限未申请");                        }                    }                }        }        super.onRequestPermissionsResult(requestCode, permissions, grantResults);    }     private void showToast(String string){        Toast.makeText(MainActivity.this,string,Toast.LENGTH_LONG).show();    } }

前提一定要注意:AndroidManifest中:

 

  //电话      //拍照       //sd卡

此案例是自己全部用Java代码写的,项目危险权限少则推荐使用,多的话就自己封装或者借助第三方了。

权限申请有很多第三方封装好的库(工具类)可以实现,Github上一大把,后续博客将找几个好一点的来讲解一下。


案例点击下载

更多相关文章

  1. [翻译]Android教程-保存数据-支持不同的平台版本
  2. Android——Json和Gson分别是什么,以及Json 数据的解析方法
  3. Android客户端和服务器交换数据的一种方案
  4. Android中Http传递参数json参数请求数据
  5. Android下通过hook技术实现透明加解密保障数据安全
  6. Android使用ApacheFtpServer实现Ftp服务器(增加用户验证)
  7. android开发中的数据库定义诀窍

随机推荐

  1. 从源码角度一步步分析AsyncTask的用法与
  2. [转】:Android生命周期
  3. Android开发者必知的开发资源(转载)
  4. Android的MediaRecorder架构介绍
  5. Android ListView元素间隙线自定义渐变效
  6. Android(安卓)动画 Kotlin 教程
  7. Universal-Image-Loader(android图片缓存)
  8. android 模拟器命令
  9. Android,Harmony 及 Java 的未来
  10. android 音标乱码的一些问题