Android 6.0蓝牙权限问题

1、分析问题:

在android 6.0(targetSdkVersion小于23)之前,安装新的app时系统会提示应用将要获取某某权限,如果同意安装,系统会默认为应用授予所申请的所有权限,而不同意的话,就不能安装应用;所以如果你以前的APP设置的targetSdkVersion低于23,在运行时是不会崩溃的。而在android 6.0(targetSdkVersion>=23)之后,我们会直接安装,不过当app需要获取不恰当权限的时候我们再决定是确定还是拒绝。
而在android 6.0之后用到蓝牙搜索的时候是需要开启模糊定位权限的,模糊定位是一个危险权限,故需要用到谷歌官方推荐的方法来解决;


2、android 6.0权限分类

android 6.0采用新的权限机制来保护用户的隐私,将权限分为Normal Permissions和Dangerous Permission;

Normal Permissions

Normal Permissions一般不涉及用户隐私,是不需要用户授权的,具体如下:
<pre><code>ACCESS_LOCATION_EXTRA_COMMANDS</code>
<code>ACCESS_NETWORK_STATE</code>
<code>ACCESS_NOTIFICATION_POLICY</code>
<code>ACCESS_WIFI_STATE</code>
<code>BLUETOOTH</code>
<code>BLUETOOTH_ADMIN</code>
<code>BROADCAST_STICKY</code>
<code>CHANGE_NETWORK_STATE</code>
<code>CHANGE_WIFI_MULTICAST_STATE</code>
<code>CHANGE_WIFI_STATE</code>
<code>DISABLE_KEYGUARD</code>
<code>EXPAND_STATUS_BAR</code>
<code>GET_PACKAGE_SIZE</code>
<code>INSTALL_SHORTCUT</code>
<code>INTERNET</code>
<code>KILL_BACKGROUND_PROCESSES</code>
<code>MODIFY_AUDIO_SETTINGS</code>
<code>NFC</code>
<code>READ_SYNC_SETTINGS</code>
<code>READ_SYNC_STATS</code>
<code>RECEIVE_BOOT_COMPLETED</code>
<code>REORDER_TASKS</code>
<code>REQUEST_INSTALL_PACKAGES</code>
<code>SET_ALARM</code>
<code>SET_TIME_ZONE</code>
<code>SET_WALLPAPER</code>
<code>SET_WALLPAPER_HINTS</code>
<code>TRANSMIT_IR</code>
<code>UNINSTALL_SHORTCUT</code>
<code>USE_FINGERPRINT</code>
<code>VIBRATE</code>
<code>WAKE_LOCK</code>
<code>WRITE_SYNC_SETTINGS</code></pre>

Dangerous Permissions

Dangerous Permissions涉及到用户隐私,在使用时需要用户实时授权才行;
<pre><code>group:android.permission-group.CONTACTS</code>
<code> permission:android.permission.WRITE_CONTACTS</code>
<code> permission:android.permission.GET_ACCOUNTS</code>
<code> permission:android.permission.READ_CONTACTS</code>

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

<code>group:android.permission-group.CALENDAR</code>
<code> permission:android.permission.READ_CALENDAR</code>
<code> permission:android.permission.WRITE_CALENDAR</code>

<code>group:android.permission-group.CAMERA</code>
<code> permission:android.permission.CAMERA</code>

<code>group:android.permission-group.SENSORS</code>
<code> permission:android.permission.BODY_SENSORS</code>

<code>group:android.permission-group.LOCATION</code>
<code> permission:android.permission.ACCESS_FINE_LOCATION</code>
<code> permission:android.permission.ACCESS_COARSE_LOCATION</code>

<code>group:android.permission-group.STORAGE</code>
<code> permission:android.permission.READ_EXTERNAL_STORAGE</code>
<code> permission:android.permission.WRITE_EXTERNAL_STORAGE</code>

<code>group:android.permission-group.MICROPHONE</code>
<code> permission:android.permission.RECORD_AUDIO</code>

<code>group:android.permission-group.SMS</code>
<code> permission:android.permission.READ_SMS</code>
<code> permission:android.permission.RECEIVE_WAP_PUSH</code>
<code> permission:android.permission.RECEIVE_MMS</code>
<code> permission:android.permission.RECEIVE_SMS</code>
<code> permission:android.permission.SEND_SMS</code>
<code> permission:android.permission.READ_CELL_BROADCASTS</code></pre>



3、模仿android官方demo处理蓝牙问题

  1. 在manifest文件中添加权限:
    <uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION" />
  2. 在代码中添加首次进入判断:
    /**
     * 校验蓝牙权限
     */
    private void checkBluetoothPermission(){
        if (Build.VERSION.SDK_INT >= 23){
            //校验是否已具有模糊定位权限
            if (ContextCompat.checkSelfPermission(mContext, Manifest.permission.ACCESS_COARSE_LOCATION)
                    != PackageManager.PERMISSION_GRANTED){
                ActivityCompat.requestPermissions(MainActivity.this, new String[]{Manifest.permission.ACCESS_COARSE_LOCATION},
                        Constants.REQUEST_CODE_REQUEST_PERMISSIONS);
            }
        }else{
            // TODO
        }
    }


            3. 对返回值进行处理,类似于startActivityForResult方法:
    @Override
    public void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions, @NonNull int[] grantResults) {
        super.onRequestPermissionsResult(requestCode, permissions, grantResults);
        switch (requestCode) {
            case Constants.REQUEST_CODE_REQUEST_PERMISSIONS:
                if (grantResults[0] == PackageManager.PERMISSION_GRANTED) {
                    // TODO request success
                } 
                break;
        }
    }

4、机型问题

一般都会在最新升级到6.0的系统出现这些问题,其中MIUI8中的问题还是很多的,有时候请求授权会莫名其妙点击不了授权框;所以每次就只能再去到权限管理页面手动更改;

5、封装推荐

在查找资料时发现其实很早以前都有很多大神处理过类似问题,并且都写有博客和github的公开项目,此处本菜鸟写出也只是简单的笔记和参考;
写的不是很明白,如还有疑问可参考鸿洋大神博客; 。其中包含有鸿洋大神自己的封装还是很方便使用的。



作者:Mr_冯先生
链接:https://www.jianshu.com/p/376b05ed8f4d
來源:简书
简书著作权归作者所有,任何形式的转载都请联系作者获得授权并注明出处。


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值