Android应用开发之运行时权限

运行时权限

Android M即6.0开始,对于某些用户敏感权限,系统不再默认授权,不仅要在AndriodManifest中声明,还要弹出系统权限框,让用户主动授权。
出于此限制,很多应用不得不修改原来的交互,加入运行时权限判断,避免因为无权限导致的功能不可用。

关于应用权限的详细介绍,可以参考官方文档:
应用权限

下面的例子是我平时项目中的一个简单应用。

代码实例

public class MainActivity extends Activity {

    private static final int MY_PERMISSIONS_REQUEST = 8000;
    private List<String> mPermissions = new ArrayList<String>();

    public void requestPermission() {
        if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.M) {
            if (mPermissions != null) {
                mPermissions.clear();
            }
			// 检查是否已经获得权限
            if (checkSelfPermission(Manifest.permission.READ_EXTERNAL_STORAGE) != PackageManager.PERMISSION_GRANTED) {
                if (mPermissions != null)
                    mPermissions.add(Manifest.permission.READ_EXTERNAL_STORAGE);
            }
            if (checkSelfPermission(Manifest.permission.WRITE_EXTERNAL_STORAGE) != PackageManager.PERMISSION_GRANTED) {
                if (mPermissions != null)
                    mPermissions.add(Manifest.permission.WRITE_EXTERNAL_STORAGE);
            }
            if (checkSelfPermission(Manifest.permission.CAMERA) != PackageManager.PERMISSION_GRANTED) {
                if (mPermissions != null)
                    mPermissions.add(Manifest.permission.CAMERA);
            }
            if (mPermissions != null && mPermissions.size() > 0) {
                requestPermissions(mPermissions.toArray(new String[]{}), MY_PERMISSIONS_REQUEST);// 批量请求权限
            } else {
                Log.d(TAG, "all permissions are granted");
            }

        }
    }
	
    @Override
    public void onRequestPermissionsResult(int requestCode, String[] permissions, int[] grantResults) {
		// 权限授权结果回调
        Log.d(TAG, "onRequestPermissionsResult requestCode:" + requestCode);
        switch (requestCode) {
            case MY_PERMISSIONS_REQUEST:
                if (grantResults != null && grantResults.length > 0) {
                    for (int i = 0; i < grantResults.length; i++) {
                        if (grantResults[i] == PackageManager.PERMISSION_GRANTED) { // 权限授权的情况可以进行业务处理
                            Log.d(TAG, "onRequestPermissionsResult(), " + permissions[i] + " is granted");
                        } else {
                            Log.d(TAG, "onRequestPermissionsResult(), " + permissions[i] + " is not granted");
                        }
                    }
                }
                break;
            default:
                super.onRequestPermissionsResult(requestCode, permissions, grantResults);
                break;
        }

    }
}

参考资料

  1. 在运行时请求权限
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值