網站首頁 編程語言 正文
AndroidMaifest.xml中聲明權限
<!-- 聲明所有需要的權限(包括普通權限和危險權限) -->
<uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE" />
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
<uses-permission android:name="android.permission.READ_CONTACTS"/>
直接上代碼,放在想要攔截的地方即可 ,一般是程序啟動時即訪問
private static final int MY_PERMISSION_REQUEST_CODE = 10000;
//第 1 步: 檢查是否有相應的權限,
boolean isAllGranted = checkPermissionAllGranted(
new String[] {
//根據自己需求,進行添加相應的權限
Manifest.permission.READ_EXTERNAL_STORAGE,
Manifest.permission.WRITE_EXTERNAL_STORAGE
}
);
// 如果權限全都擁有, 則直接初始化日志文件
if (isAllGranted) {
configureLog4J.configure();//有權限之后要做的事情
return;
}
//第 2 步: 請求權限
// 一次請求多個權限, 如果其他有權限是已經授予的將會自動忽略掉
ActivityCompat.requestPermissions(
this,
new String[] {
Manifest.permission.READ_EXTERNAL_STORAGE,
Manifest.permission.WRITE_EXTERNAL_STORAGE
},
MY_PERMISSION_REQUEST_CODE
);
//檢查是否擁有指定的所有權限
private boolean checkPermissionAllGranted(String[] permissions) {
for (String permission : permissions) {
if (ContextCompat.checkSelfPermission(this, permission) != PackageManager.PERMISSION_GRANTED) {
// 只要有一個權限沒有被授予, 則直接返回 false
return false;
}
}
return true;
}
//第 3 步: 申請權限結果返回處理
@Override
public void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions, @NonNull int[] grantResults) {
super.onRequestPermissionsResult(requestCode, permissions, grantResults);
if (requestCode == MY_PERMISSION_REQUEST_CODE) {
boolean isAllGranted = true;
// 判斷是否所有的權限都已經授予了
for (int grant : grantResults) {
if (grant != PackageManager.PERMISSION_GRANTED) {
isAllGranted = false;
break;
}
}
if (isAllGranted) {
// 如果所有的權限都授予了, 則初始化日志文件
configureLog4J.configure();//有權限之后要做的事情
} else {
// 彈出對話框告訴用戶需要權限的原因, 并引導用戶去應用權限管理中手動打開權限按鈕
openAppDetails();
}
}
}
//打開 APP 的詳情設置
private void openAppDetails() {
AlertDialog.Builder builder = new AlertDialog.Builder(this);
builder.setMessage("該程序需要訪問 “外部存儲器”,請到 “應用信息 -> 權限” 中授予!");
builder.setPositiveButton("去手動授權", new DialogInterface.OnClickListener() {
@Override
public void onClick(DialogInterface dialog, int which) {
Intent intent = new Intent();
intent.setAction(Settings.ACTION_APPLICATION_DETAILS_SETTINGS);
intent.addCategory(Intent.CATEGORY_DEFAULT);
intent.setData(Uri.parse("package:" + getPackageName()));
intent.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
intent.addFlags(Intent.FLAG_ACTIVITY_NO_HISTORY);
intent.addFlags(Intent.FLAG_ACTIVITY_EXCLUDE_FROM_RECENTS);
startActivity(intent);
}
});
builder.setNegativeButton("取消", null);
builder.show();
}
原文鏈接:https://www.cnblogs.com/fjn-blogs/archive/2022/09/29/16741432.html
相關推薦
- 2022-05-14 基于Unity編寫一個九宮格抽獎軟件_C#教程
- 2022-11-17 VMware?vSphere?ESXi系統設置靜態IP的方法_VMware
- 2021-12-13 在Centos7中配置NIS的詳細過程_Linux
- 2022-09-04 C/C++?引用作為函數的返回值方式_C 語言
- 2022-06-17 Ruby操作CSV格式數據方法詳解_ruby專題
- 2022-02-25 image-webpack-loader 報錯 Invalid regular expression
- 2022-05-11 在 Markdown 中,如何在反引號對語句中使用反引號
- 2022-09-22 哈希思想的經典應用(位圖,哈希切割)
- 最近更新
-
- window11 系統安裝 yarn
- 超詳細win安裝深度學習環境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權
- redisson分布式鎖中waittime的設
- maven:解決release錯誤:Artif
- restTemplate使用總結
- Spring Security之安全異常處理
- MybatisPlus優雅實現加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發現-Nac
- Spring Security之基于HttpR
- Redis 底層數據結構-簡單動態字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支