android判断版本做不同的操作,android - 为不同的版本做权限判断(check permission)

android - 为不同的版本做权限判断(check permission)

2017-09-02 14:56

访问量: 2300

分类:

技术

在5.1 (sdk 22)之前, 权限是在一开始安装的时候确定的。

在6.0 (sdk 23)之后, 权限是在运行时检查的。目的是为了简化安装过程。

下面的代码,就可以针对不同的平台做检查。

写在Activity中:

// 定义这个常量, 用来申请权限的时候 做个记号。

private static final int MY_PERMISSIONS_REQUEST_READ_CONTACTS = 3;

public voic onCreate(...){

// 检查相机权限

if(Build.VERSION.SDK_INT >= Build.VERSION_CODES.M){

Log.d(TAG, "== requestPermissions: ");

if( ContextCompat.checkSelfPermission(this, Manifest.permission.CAMERA) != PackageManager.PERMISSION_GRANTED)

ActivityCompat.requestPermissions(this, new String[]{Manifest.permission.READ_CONTACTS}, MY_PERMISSIONS_REQUEST_READ_CONTACTS);

}else{

Log.d(TAG, "== just show alert");

// 给出alert

AlertDialog.Builder builder = new AlertDialog.Builder(this);

builder.setMessage("请您为“XXX”赋予“相机权限”。打开“设置 -> 一般 -> 安全 -> 应用程序权限, 找到”XX“,然后在“相机”权限打钩")

.setTitle(R.string.request_permission_for_camera_title)

.setPositiveButton(R.string.got_it, new DialogInterface.OnClickListener() {

@Override

public void onClick(DialogInterface dialog, int which) {

finish();

}

})

.setCancelable(false);

builder.show();

}

@Override

public void onRequestPermissionsResult(int requestCode, String permissions[], int[] grantResults){

switch (requestCode){

case MY_PERMISSIONS_REQUEST_READ_CONTACTS: {

if(grantResults.length > 0

&& grantResults[0] == PackageManager.PERMISSION_GRANTED){

Log.d(TAG, "== got permission of camera");

}else{

finish();

}

return;

}

}

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
回答: 检查权限的目的是为了确保应用程序在访问敏感数据或执行敏感操作之前获得用户的授权。Android系统将权限分为两类:Normal类和Dangerous类。Normal类的权限不会直接涉及到用户隐私风险,而Dangerous类的权限可能会让应用程序涉及到用户机密的数据。如果应用程序在Manifest文件中声明了Normal类的权限,系统会自动授予这些权限。但如果应用程序在Manifest文件中声明了Dangerous类的权限,用户必须明确授予对应的权限后,应用程序才能具有这些权限。\[1\] 在开发过程中,开发者需要在Manifest文件中声明所需的权限,并在代码中检查是否已经获得了这些权限。如果没有获得权限,应用程序可能会抛出SecurityException异常,提示缺少权限。开发者可以使用Android提供的权限管理机制来请求和检查权限。具体的权限申请方法可以在开发者文档中找到相关信息。\[1\] 在特定的开发环境中,比如在微信小程序中,可能需要在配置文件中声明权限。例如,在pages.json文件中配置了用户位置信息的权限,以便在展示附近商家位置信息时使用。\[2\] 总之,检查权限是为了确保应用程序在访问敏感数据或执行敏感操作之前获得用户的授权,以保护用户的隐私和数据安全。 #### 引用[.reference_title] - *1* *3* [Android Permission check的一点认知更新](https://blog.csdn.net/mrdone/article/details/77867500)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down28v1,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [uniapp小程序定位 配置permission失败问题](https://blog.csdn.net/qq_38881495/article/details/123232436)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down28v1,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值