Android声明权限

如何向AndroidManifest中添加权限?

将<uses-permission>元素作为顶级<manifest>元素的子项。例如发送短信的权限可在AndroidManifest添加以下代码行:

<manifest xmlns:android="http://schemas.android.com/apk/res/android" package="com.example.snazzyapp">

        <uses-permission android:name="android.permission.SEND_SMS"/>

        <application...>
            ...
        </application>

    </manifest>

正常权限和危险权限

  • 正常权限涵盖应用访问其沙盒外部数据或资源,但对用户隐私或其他应用操作风险很小的区域,如获取时区的权限。
  • 危险权限涵盖应用涉及用户隐私信息的数据或资源,或者可能对用户存储的数据或其他应用的操作产生影响的区域。如读取用户联系人属于危险权限。

系统版本和应用targetSdkVersion对声明权限的影响

  • 设备运行在Android 5.1或更低版本,或targetSdkVersion为22或更低
    如果在清单中列出了危险权限,用户在安装应用时授予此权限,如果用户不授予此权限,系统不会安装应用。
  • 设备运行在Android 6.0或更高版本,或targetSdkVersion为23或更高
    应用必须在清单中列出权限,且必须在运行时请求其需要的每项危险权限。用户可授予或拒绝每项权限,且即使用户拒接权限请求,应用仍可继续运行有限的功能。

检查权限

要检查是否具有某项权限,可调用ContextCompat.checkSelfPermission()方法。例如:

  /* 
    *如果应用具有此权限,方法返回 PackageManager.PERMISSION_GRANTED
    *如果应用不具有此权限,方法返回 PackageManager.PERMISSION_DENIED
     */
    int permissionCheck = ContextCompat.checkSelfPermission(this, Manifest.permission.WRITE_CALENDAR);

请求您需要的权限

请求权限:requestPermissions()

if (ContextCompat.checkSelfPermission(this, Manifest.permission.READ_CONTACTS) != PackageManager.PERMISSION_GRANTED) {
        // Should we show an explanation?
        if (ActivityCompat.shouldShowRequestPermissionRationale(this,
                Manifest.permission.READ_CONTACTS)) {

        } else {
            // No explanation needed, we can request the permission.
            // 当应用调用requestPermissions()时,系统向用户显示一个标准对话框
            ActivityCompat.requestPermissions(this,
                    new String[]{Manifest.permission.READ_CONTACTS},
                    MY_PERMISSIONS_REQUEST_READ_CONTACTS);
            // MY_PERMISSIONS_REQUEST_READ_CONTACTS is an
            // app-defined int constant. The callback method gets the
            // result of the request.
        }
    }

响应权限请求

在应用请求权限时,系统将向用户显示一个对话框。当用户响应后,系统将调用onRequestPermissionsResult()方法,向其传递用户作出响应。例如:

@Override
    public void onRequestPermissionsResult(int requestCode, String permissions[], int[] grantResults) {
        switch (requestCode) {
            case MY_PERMISSIONS_REQUEST_READ_CONTACTS: {
                // If request is cancelled, the result arrays are empty.
                if (grantResults.length > 0
                        && grantResults[0] == PackageManager.PERMISSION_GRANTED) {

                    // permission was granted, yay! Do the
                    // contacts-related task you need to do.

                } else {

                    // permission denied, boo! Disable the
                    // functionality that depends on this permission.
                }
                return;
            }

            // other 'case' lines to check for other
            // permissions this app might request
        }
    }
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Android 是一个特权分离(privilege-separated)操作系统,在其中每个应用都以一个不同的系统...
    DanieX阅读 4,139评论 0 3
  • 本文为菜鸟窝作者蒋志碧的连载。“从 0 开始开发一款直播 APP ”系列来聊聊时下最火的直播 APP,如何完整的实...
    菜鸟窝阅读 1,071评论 1 10
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 135,026评论 19 139
  • 不知不觉中又到了年底,去年的这个时候,你让我过了一个终生难忘的一个生日,因为家里人记得是农历生日,生份证上又是另外...
    ARCHP阅读 213评论 0 0
  • 何事惹人愁,薄凉似深秋。听叶落,瑟瑟到心头。残花飞过溪边柳,声声问,盼可留。 丝雨落轻舟,两岸...
    请叫我想念熊阅读 218评论 3 2