關于 HarmonyOS 的動態授權的常規操作流程和代碼我之前寫過一篇文章:《鴻蒙動態權限申請完整規范流程和操作詳解》。
文章地址如下:
https://harmonyos.51cto.com/posts/5165
權限控制是在進行 HarmonyOS 應用開發中非常重要的一個環節,幾乎所有的商業應用中都會涉及到。
我們在曾經使用的 Android app 應用中經常會遇到一些 app 會彈出各種敏感權限授權窗口提示用戶授權。
有些 app(特別是流氓應用)經常會在第一次打開 app 的時候就提醒用戶授予所有需要的權限。
甚至一些權限跟 app 功能根本不相關(比如讀取通訊錄等),如果不授權則直接不讓你使用該 app,我遇到這類流氓應用一般果斷卸載。
而真正的開發過程中我們在權限申請的時候一般要遵循以下 3 個原則:
最小權限集,即應用中確實需要的權限才進行申請。
需要用到 XX 權限時才進行申請,即并不是 app 開始的時候一次性申請所有權限,而是需要用到 XX 特定功能必須要授權才能使用的時候(比如調用照相機),這個時候才申請該特定權限。
未獲取用戶授權的話依然能使用應用大部分功能,只是必須授權的功能無法使用。
下面我針對敏感權限申請更好的復用,編寫了一個第三方開源組件,取名為 XdwPermissionsLib。
具體項目源碼請見:
https://gitee.com/xdw1019/XdwPermissionsLib
XdwPermissionsLib 介紹
鴻蒙權限請求框架,提供一個符合正規權限調用流程的框架并基于鏈式調用(這里簡稱 strong 模式),同時提供一個并不推薦使用的簡單權限框架(簡稱 lazy 模式)。
strong 模式:正式項目推薦使用該模式。正規權限處理流程,用戶需要檢驗權限并且處理校驗結果的回調。
lazy 模式:該模式下開發者幾乎不用去編寫請求權限的代碼,特別是不處理回調。
該模式不推薦在正式項目中使用,可以用于平時編寫某些 demo 又不想處理權限的場景下。
當然有些 app 不在乎用戶體驗,只要不授權就不讓使用的情況可以使用該模式。
動態申請權限流程圖如下:
使用說明
①Strong 模式
引用:
方式一:通過 mylibrary 模塊生成 har 包,添加 har 包到 libs 文件夾內
方式二:maven 引入(待后續上傳到 maven 中心倉庫再支持)
定義權限組,比如:
//定義需要動態申請的權限組,可以是一個或多個權限。這里的權限還必須要在config.json中進行配置
private String[] permissions = {
// 存儲權限
SystemPermission.WRITE_USER_STORAGE,
// 相機權限
SystemPermission.CAMERA
};
在需要觸發權限申請的地方調用如下代碼:
//開始動態申請權限,鏈式調用。//實際開發中申請權限的動作應該放到需要用到該權限的操作中觸發,比如點擊某個按鈕調起相機 StrongPermissionsUtils.getInstance(this).checkPermissions(this,permissions).setPermissionStateListener(new StrongPermissionsUtils.PermissionStateListener() {
@Override
public void onPermissionGranted() {
//授權成功之后的回調
//此處根據自己的實際業務編寫業務邏輯,此處用toast進行演示
ToastUtil.toast(getContext(),“授權成功”);
}
@Override
public void onPermissionDenied(boolean isDisabledPrompt) {
//授權拒絕之后的回調
//此處根據自己的實際業務編寫業務邏輯,此處用toast進行演示
if(isDisabledPrompt){
ToastUtil.toast(getContext(),“您之前拒絕了授權并且禁止系統再提示,需要手動進入系統設置頁面開啟”);
}else{
ToastUtil.toast(getContext(),“您拒絕了授權”);
}
}
});
在當前的 ability 重寫 onRequestPermissionsFromUserResult 方法,代碼如下:
@Overridepublic void onRequestPermissionsFromUserResult(int requestCode, String[] permissions, int[] grantResults) {
super.onRequestPermissionsFromUserResult(requestCode, permissions, grantResults);
//鑒權之后的回調,必須調用
StrongPermissionsUtils.getInstance(this).onRequestPermissionsResult(requestCode, permissions, grantResults);
}
②Lazy 模式
引用:
方式一:通過 mylibrary 模塊生成 har 包,添加 har 包到 libs 文件夾內
方式二:maven 引入(待后續上傳到 maven 中心倉庫再支持)
將需要調用的 Ability 繼承 LazyPermissionAblity,如下:
public class MainAbility extends LazyPermissionAblity {
在當前 Ability 中定義權限組,并且在 onStart 方法的第一行調用 setPermissions 方法。
代碼如下:
public class MainAbility extends LazyPermissionAblity {
//定義需要動態申請的權限組,可以是一個或多個權限。這里的權限還必須要在config.json中進行配置
private String[] permissions = {
// 存儲權限
SystemPermission.WRITE_USER_STORAGE,
// 相機權限
SystemPermission.CAMERA
};
@Override
public void onStart(Intent intent) {
//lazy模式下,setPermissions的代碼調用必須放在onStart的第一行
super.setPermissions(permissions);
super.onStart(intent);
super.setMainRoute(MainAbilitySlice.class.getName());
}
}
工程結構說明
工程中總共有三個 module,分別為:
mylibrary:自定義的第三方權限庫,供外部項目調用。
entry:用來演示 mylibrary 庫中 strong 模式下的權限調用。
LazySample:用來演示 mylibrary 庫中 lazy 模式下的權限調用。
責任編輯:haq
-
APP
+關注
關注
33文章
1575瀏覽量
72576 -
鴻蒙系統
+關注
關注
183文章
2636瀏覽量
66452 -
HarmonyOS
+關注
關注
79文章
1980瀏覽量
30287
原文標題:鴻蒙APP開發:權限控制詳解!
文章出處:【微信號:gh_834c4b3d87fe,微信公眾號:OpenHarmony技術社區】歡迎添加關注!文章轉載請注明出處。
發布評論請先 登錄
相關推薦
評論