偷偷摘套内射激情视频,久久精品99国产国产精,中文字幕无线乱码人妻,中文在线中文a,性爽19p

HarmonyOS自定義權(quán)限組件--你真的弄懂了權(quán)限控制了嗎?

系統(tǒng) OpenHarmony
鴻蒙權(quán)限請求框架,提供一個符合正規(guī)權(quán)限調(diào)用流程的框架并基于鏈式調(diào)用(這里簡稱strong模式),同時提供一個并不推薦使用的簡單權(quán)限框架(簡稱lazy模式)。

[[424081]]

想了解更多內(nèi)容,請訪問:

51CTO和華為官方合作共建的鴻蒙技術(shù)社區(qū)

https://harmonyos.51cto.com

前言

關(guān)于HarmonyOS的動態(tài)授權(quán)的常規(guī)操作流程和代碼我之前寫過一篇文章,請看《鴻蒙動態(tài)權(quán)限申請完整規(guī)范流程和操作詳解(https://harmonyos.51cto.com/posts/5165)》。

權(quán)限控制是在進行HarmonyOS應(yīng)用開發(fā)中非常重要的一個環(huán)節(jié),幾乎所有的商業(yè)應(yīng)用中都會涉及到。我們在曾經(jīng)使用的Android app應(yīng)用中經(jīng)常會遇到一些app會彈出各種敏感權(quán)限授權(quán)窗口提示用戶授權(quán),有些app(特別是流氓應(yīng)用)經(jīng)常會在第一次打開app的時候就提醒用戶授予所有需要的權(quán)限,甚至一些權(quán)限跟app功能根本不相關(guān)(比如讀取通訊錄等),如果不授權(quán)則直接不讓你使用該app,我遇到這類流氓應(yīng)用一般果斷卸載。而真正的開發(fā)過程中我們在權(quán)限申請的時候一般要遵循以下3個原則:

1、最小權(quán)限集,即應(yīng)用中確實需要的權(quán)限才進行申請。

2、需要用到XX權(quán)限時才進行申請,即并不是app開始的時候一次性申請所有權(quán)限,而是需要用到XX特定功能必須要授權(quán)才能使用的時候(比如調(diào)用照相機),這個時候才申請該特定權(quán)限。

3、未獲取用戶授權(quán)的話依然能使用應(yīng)用大部分功能,只是必須授權(quán)的功能無法使用。

下面我針對敏感權(quán)限申請更好的復(fù)用,編寫了一個第三方開源組件,取名為XdwPermissionsLib。

具體項目源碼請見https://gitee.com/xdw1019/XdwPermissionsLib

XdwPermissionsLib

介紹

鴻蒙權(quán)限請求框架,提供一個符合正規(guī)權(quán)限調(diào)用流程的框架并基于鏈式調(diào)用(這里簡稱strong模式),同時提供一個并不推薦使用的簡單權(quán)限框架(簡稱lazy模式)。

strong模式:正式項目推薦使用該模式。正規(guī)權(quán)限處理流程,用戶需要檢驗權(quán)限并且處理校驗結(jié)果的回調(diào)。

lazy模式:該模式下開發(fā)者幾乎不用去編寫請求權(quán)限的代碼,特別是不處理回調(diào)。該模式不推薦在正式項目中使用,可以用于平時編寫某些demo又不想處理權(quán)限的場景下。當(dāng)然有些app不在乎用戶體驗,只要不授權(quán)就不讓使用的情況可以使用該模式。

動態(tài)申請權(quán)限流程圖

運行效果圖展示:

Strong模式下的效果圖:

圖片待補充

lazy模式下的效果圖:

圖片待補充

使用說明

Strong模式:

1.引用

方式一: 通過mylibrary模塊生成har包,添加har包到libs文件夾內(nèi)

方式二:maven引入(待后續(xù)上傳到maven中心倉庫再支持)

2.定義權(quán)限組,比如:

  1. //定義需要動態(tài)申請的權(quán)限組,可以是一個或多個權(quán)限。這里的權(quán)限還必須要在config.json中進行配置 
  2.    private String[] permissions = { 
  3.            // 存儲權(quán)限 
  4.            SystemPermission.WRITE_USER_STORAGE, 
  5.            // 相機權(quán)限 
  6.            SystemPermission.CAMERA 
  7.    }; 

 3.在需要觸發(fā)權(quán)限申請的地方調(diào)用如下代碼:

  1. //開始動態(tài)申請權(quán)限,鏈式調(diào)用。 
  2. //實際開發(fā)中申請權(quán)限的動作應(yīng)該放到需要用到該權(quán)限的操作中觸發(fā),比如點擊某個按鈕調(diào)起相機    StrongPermissionsUtils.getInstance(this).checkPermissions(this,permissions).setPermissionStateListener(new StrongPermissionsUtils.PermissionStateListener() { 
  3.             @Override 
  4.             public void onPermissionGranted() { 
  5.                 //授權(quán)成功之后的回調(diào) 
  6.                 //此處根據(jù)自己的實際業(yè)務(wù)編寫業(yè)務(wù)邏輯,此處用toast進行演示 
  7.                 ToastUtil.toast(getContext(),"授權(quán)成功"); 
  8.             } 
  9.  
  10.             @Override 
  11.             public void onPermissionDenied(boolean isDisabledPrompt) { 
  12.                 //授權(quán)拒絕之后的回調(diào) 
  13.                 //此處根據(jù)自己的實際業(yè)務(wù)編寫業(yè)務(wù)邏輯,此處用toast進行演示 
  14.                 if(isDisabledPrompt){ 
  15.                     ToastUtil.toast(getContext(),"您之前拒絕了授權(quán)并且禁止系統(tǒng)再提示,需要手動進入系統(tǒng)設(shè)置頁面開啟"); 
  16.                 }else
  17.                     ToastUtil.toast(getContext(),"您拒絕了授權(quán)"); 
  18.                 } 
  19.             } 
  20.         }); 

4.在當(dāng)前的ability重寫onRequestPermissionsFromUserResult方法,代碼如下:

  1. @Override 
  2. public void onRequestPermissionsFromUserResult(int requestCode, String[] permissions, int[] grantResults) { 
  3.         super.onRequestPermissionsFromUserResult(requestCode, permissions, grantResults); 
  4.         //鑒權(quán)之后的回調(diào),必須調(diào)用 
  5.         StrongPermissionsUtils.getInstance(this).onRequestPermissionsResult(requestCode, permissions, grantResults); 
  6.     } 

Lazy模式:

1.引用

方式一: 通過mylibrary模塊生成har包,添加har包到libs文件夾內(nèi)

方式二:maven引入(待后續(xù)上傳到maven中心倉庫再支持)

2、將需要調(diào)用的Ability繼承LazyPermissionAblity,如下:

  1. public class MainAbility extends LazyPermissionAblity { 

3、在當(dāng)前Ability中定義權(quán)限組,并且在onStart方法的第一行調(diào)用setPermissions方法,如下:

  1. public class MainAbility extends LazyPermissionAblity { 
  2.     //定義需要動態(tài)申請的權(quán)限組,可以是一個或多個權(quán)限。這里的權(quán)限還必須要在config.json中進行配置 
  3.     private String[] permissions = { 
  4.             // 存儲權(quán)限 
  5.             SystemPermission.WRITE_USER_STORAGE, 
  6.             // 相機權(quán)限 
  7.             SystemPermission.CAMERA 
  8.     }; 
  9.     @Override 
  10.     public void onStart(Intent intent) { 
  11.         //lazy模式下,setPermissions的代碼調(diào)用必須放在onStart的第一行 
  12.         super.setPermissions(permissions); 
  13.         super.onStart(intent); 
  14.         super.setMainRoute(MainAbilitySlice.class.getName()); 
  15.     } 

工程結(jié)構(gòu)說明

工程中總共有三個module,分別為mylibrary、entry和LazySample。

mylibrary: 自定義的第三方權(quán)限庫,供外部項目調(diào)用。

entry: 用來演示mylibrary庫中strong模式下的權(quán)限調(diào)用。

LazySample: 用來演示mylibrary庫中l(wèi)azy模式下的權(quán)限調(diào)用。

文章相關(guān)附件可以點擊下面的原文鏈接前往下載

https://harmonyos.51cto.com/resource/1195

想了解更多內(nèi)容,請訪問:

51CTO和華為官方合作共建的鴻蒙技術(shù)社區(qū)

https://harmonyos.51cto.com

 

責(zé)任編輯:jianghua 來源: 鴻蒙社區(qū)
相關(guān)推薦

2018-10-20 16:05:12

iOSAPP開發(fā)

2022-07-27 08:01:29

CMS垃圾回收器

2022-04-07 08:20:22

typeinterface前端

2022-03-08 15:01:48

負載均衡IP服務(wù)器

2022-02-17 07:10:39

Nest自定義注解

2023-02-20 15:20:43

啟動頁組件鴻蒙

2022-05-06 09:21:21

TypeScriptinterfacetype

2017-02-14 12:34:28

iOSAllocInit

2022-04-24 15:17:56

鴻蒙操作系統(tǒng)

2022-10-26 15:54:46

canvas組件鴻蒙

2022-10-25 15:12:24

自定義組件鴻蒙

2025-03-13 07:33:46

Spring項目開發(fā)

2022-02-21 15:16:30

HarmonyOS鴻蒙操作系統(tǒng)

2022-06-20 15:43:45

switch開關(guān)鴻蒙

2021-12-21 15:22:22

鴻蒙HarmonyOS應(yīng)用

2022-06-27 08:16:34

JSON格式序列化

2018-01-05 10:47:59

前端JavascriptWeb

2021-10-10 20:36:49

Android Root權(quán)限

2013-12-26 09:44:30

互聯(lián)網(wǎng)物聯(lián)網(wǎng)區(qū)別

2013-07-15 16:55:45

點贊
收藏

51CTO技術(shù)棧公眾號