0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

鴻蒙開發(fā)Ability Kit程序訪問控制:使用保存控件

jf_46214456 ? 來源:jf_46214456 ? 作者:jf_46214456 ? 2024-07-03 14:40 ? 次閱讀

使用保存控件

保存控件是一種特殊的安全控件,它允許用戶通過點(diǎn)擊按鈕臨時(shí)獲取存儲權(quán)限,而無需通過權(quán)限彈框進(jìn)行授權(quán)確認(rèn)。

集成保存控件后,當(dāng)用戶點(diǎn)擊該控件時(shí),應(yīng)用會(huì)獲得10秒內(nèi)單次訪問媒體庫特權(quán)接口的授權(quán)。這適用于任何需要將文件保存到媒體庫的應(yīng)用場景,例如保存圖片或視頻等。

與需要觸發(fā)系統(tǒng)應(yīng)用并由用戶選擇具體保存路徑的Picker不同,保存控件可以直接保存到指定的媒體庫路徑,使得操作更為便捷。

保存控件效果如圖所示。

1.png

約束與限制

  • 應(yīng)用在onClick()觸發(fā)回調(diào)到調(diào)用媒體庫特權(quán)接口的時(shí)間間隔不能大于10秒。
  • 用戶點(diǎn)擊一次控件,僅獲取一次授權(quán)調(diào)用。
  • 為了保障用戶的隱私不被惡意應(yīng)用獲取,應(yīng)用需確保安全控件是可見的且用戶能夠識別的。開發(fā)者需要合理的配置控件的尺寸、顏色等屬性,避免視覺混淆的情況,如果發(fā)生因控件的樣式不合法導(dǎo)致授權(quán)失敗的情況,請檢查設(shè)備錯(cuò)誤日志。
  • 開發(fā)前請熟悉鴻蒙開發(fā)指導(dǎo)文檔 :[gitee.com/li-shizhen-skin/harmony-os/blob/master/README.md]

開發(fā)步驟

以保存對話中圖片為例,應(yīng)用僅需要在前臺期間,短暫使用保存圖片的特性,不需要長時(shí)間使用。此時(shí),可以直接使用安全控件中的保存控件,免去權(quán)限申請和權(quán)限請求等環(huán)節(jié),獲得臨時(shí)授權(quán),保存對應(yīng)圖片。

  1. 導(dǎo)入文件和媒體庫依賴。

    import { photoAccessHelper } from '@kit.MediaLibraryKit';
    import { fileIo } from '@kit.CoreFileKit';
    
  2. 設(shè)置圖片資源,并添加保存控件。
    保存控件是一種類似于按鈕的安全控件,由圖標(biāo)、文本和背景組成。其中,圖標(biāo)和文本至少需要有一個(gè),背景是可選的。圖標(biāo)和文本不能自定義,只能從已有的選項(xiàng)中選擇。在聲明安全控件的接口時(shí),有傳參和不傳參兩種方式。不傳參將默認(rèn)創(chuàng)建一個(gè)包含圖標(biāo)、文字和背景的按鈕,傳參則根據(jù)參數(shù)創(chuàng)建,不包含未配置的元素。
    當(dāng)前示例使用默認(rèn)參數(shù)。具體請參見[SaveButton控件]。此外,所有安全控件都繼承[安全控件通用屬性],可用于定制樣式。
    搜狗高速瀏覽器截圖20240326151450.png

    `HarmonyOSOpenHarmony鴻蒙文檔籽料:mau123789是v直接拿`
    import { photoAccessHelper } from '@kit.MediaLibraryKit';
    import { fileIo } from '@kit.CoreFileKit';
    import { common } from '@kit.AbilityKit';
    import { promptAction } from '@kit.ArkUI';
    import { BusinessError } from '@kit.BasicServicesKit';
    
    async function savePhotoToGallery(context: common.UIAbilityContext) {
      let helper = photoAccessHelper.getPhotoAccessHelper(context);
      try {
        // onClick觸發(fā)后5秒內(nèi)通過createAsset接口創(chuàng)建圖片文件,5秒后createAsset權(quán)限收回。
        let uri = await helper.createAsset(photoAccessHelper.PhotoType.IMAGE, 'jpg');
        // 使用uri打開文件,可以持續(xù)寫入內(nèi)容,寫入過程不受時(shí)間限制
        let file = await fileIo.open(uri, fileIo.OpenMode.READ_WRITE | fileIo.OpenMode.CREATE);
        context.resourceManager.getMediaContent($r('app.media.icon').id, 0)
          .then(async value = > {
            let media = value.buffer;
            // 寫到媒體庫文件中
            await fileIo.write(file.fd, media);
            await fileIo.close(file.fd);
            promptAction.showToast({ message: '已保存至相冊!' });
          });
      }
      catch (error) {
        const err: BusinessError = error as BusinessError;
        console.error(`Failed to save photo. Code is ${err.code}, message is ${err.message}`);
      }
    }
    
    @Entry
    @Component
    struct Index {
      build() {
        Row() {
          Column({ space: 10 }) {
            Image($r('app.media.icon'))
              .height(400)
              .width('100%')
    
            SaveButton().onClick(async (event: ClickEvent, result: SaveButtonOnClickResult) = > {
              if (result === SaveButtonOnClickResult.SUCCESS) {
                const context: common.UIAbilityContext = getContext(this) as common.UIAbilityContext;
                // 免去權(quán)限申請和權(quán)限請求等環(huán)節(jié),獲得臨時(shí)授權(quán),保存對應(yīng)圖片
                savePhotoToGallery(context);
              } else {
                promptAction.showToast({ message: '設(shè)置權(quán)限失?。? })
              }
            })
          }
          .width('100%')
        }
        .height('100%')
        .backgroundColor(0xF1F3F5)
      }
    }
    

    審核編輯 黃宇

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報(bào)投訴
  • 鴻蒙
    +關(guān)注

    關(guān)注

    57

    文章

    2352

    瀏覽量

    42863
收藏 人收藏

    評論

    相關(guān)推薦

    鴻蒙開發(fā)接口Ability框架:【@ohos.application.Ability (Ability)】

    Ability模塊提供對Ability生命周期、上下文環(huán)境等調(diào)用管理的能力,包括Ability創(chuàng)建、銷毀、轉(zhuǎn)儲客戶端信息等。
    的頭像 發(fā)表于 04-30 17:42 ?2268次閱讀
    <b class='flag-5'>鴻蒙</b><b class='flag-5'>開發(fā)</b>接口<b class='flag-5'>Ability</b>框架:【@ohos.application.<b class='flag-5'>Ability</b> (<b class='flag-5'>Ability</b>)】

    鴻蒙開發(fā)接口Ability框架:【 (Context模塊)】

    Context模塊提供了ability或application的上下文的能力,包括允許訪問特定于應(yīng)用程序的資源、請求和驗(yàn)證權(quán)限等。
    的頭像 發(fā)表于 05-13 16:04 ?721次閱讀
    <b class='flag-5'>鴻蒙</b><b class='flag-5'>開發(fā)</b>接口<b class='flag-5'>Ability</b>框架:【 (Context模塊)】

    鴻蒙Ability開發(fā)-Stage模型下Ability的創(chuàng)建和使用

    Ability開發(fā)技術(shù)的簡單運(yùn)用,更多的鴻蒙開發(fā)技術(shù)可以前往我主頁查詢,下面分享鴻蒙開發(fā)4.0
    發(fā)表于 01-08 15:34

    跟阿斌一起學(xué)鴻蒙(2): Ability vs App?

    在進(jìn)一步實(shí)踐之前,需要先弄明白一個(gè)概念:Ability。不知道你有沒有注意到,使用鴻蒙開發(fā)工具DevEco Studio創(chuàng)建項(xiàng)目時(shí),我們選擇創(chuàng)建的是一個(gè)個(gè)Ability。這是為什么呢?
    發(fā)表于 11-30 20:56

    鴻蒙應(yīng)用模型:【Ability Kit】簡介

    Ability Kit程序框架服務(wù))提供了應(yīng)用程序開發(fā)和運(yùn)行的應(yīng)用模型,是系統(tǒng)為開發(fā)者提供的應(yīng)
    的頭像 發(fā)表于 05-29 14:41 ?658次閱讀
    <b class='flag-5'>鴻蒙</b>應(yīng)用模型:【<b class='flag-5'>Ability</b> <b class='flag-5'>Kit</b>】簡介

    鴻蒙Ability Kit程序框架服務(wù))【Ability內(nèi)頁面間的跳轉(zhuǎn)】

    基于Stage模型下的Ability開發(fā),實(shí)現(xiàn)Ability內(nèi)頁面間的跳轉(zhuǎn)和數(shù)據(jù)傳遞。
    的頭像 發(fā)表于 06-03 20:43 ?303次閱讀
    <b class='flag-5'>鴻蒙</b><b class='flag-5'>Ability</b> <b class='flag-5'>Kit</b>(<b class='flag-5'>程序</b>框架服務(wù))【<b class='flag-5'>Ability</b>內(nèi)頁面間的跳轉(zhuǎn)】

    鴻蒙Ability Kit程序框架服務(wù))【Ability與ServiceExtensionAbility通信】

    本示例展示通過[IDL的方式]和?[@ohos.rpc]?等接口實(shí)現(xiàn)了Ability與ServiceExtensionAbility之間的通信。
    的頭像 發(fā)表于 06-05 09:28 ?494次閱讀
    <b class='flag-5'>鴻蒙</b><b class='flag-5'>Ability</b> <b class='flag-5'>Kit</b>(<b class='flag-5'>程序</b>框架服務(wù))【<b class='flag-5'>Ability</b>與ServiceExtensionAbility通信】

    鴻蒙開發(fā)Ability Kit程序框架服務(wù):訪問控制概述 程序訪問控制

    默認(rèn)情況下,應(yīng)用只能訪問有限的系統(tǒng)資源。但某些情況下,應(yīng)用存在擴(kuò)展功能的訴求,需要訪問額外的系統(tǒng)數(shù)據(jù)(包括用戶個(gè)人數(shù)據(jù))和功能,系統(tǒng)也必須以明確的方式對外提供接口來共享其數(shù)據(jù)或功能。
    的頭像 發(fā)表于 07-01 15:53 ?298次閱讀
    <b class='flag-5'>鴻蒙</b><b class='flag-5'>開發(fā)</b><b class='flag-5'>Ability</b> <b class='flag-5'>Kit</b><b class='flag-5'>程序</b>框架服務(wù):<b class='flag-5'>訪問</b><b class='flag-5'>控制</b>概述 <b class='flag-5'>程序</b><b class='flag-5'>訪問</b><b class='flag-5'>控制</b>

    鴻蒙開發(fā)Ability Kit程序框架服務(wù):應(yīng)用權(quán)限管控概述 程序訪問控制

    系統(tǒng)提供了一種允許應(yīng)用訪問系統(tǒng)資源(如:通訊錄等)和系統(tǒng)能力(如:訪問攝像頭、麥克風(fēng)等)的通用權(quán)限訪問方式,來保護(hù)系統(tǒng)數(shù)據(jù)(包括用戶個(gè)人數(shù)據(jù))或功能,避免它們被不當(dāng)或惡意使用。
    的頭像 發(fā)表于 07-01 10:21 ?472次閱讀
    <b class='flag-5'>鴻蒙</b><b class='flag-5'>開發(fā)</b><b class='flag-5'>Ability</b> <b class='flag-5'>Kit</b><b class='flag-5'>程序</b>框架服務(wù):應(yīng)用權(quán)限管控概述 <b class='flag-5'>程序</b><b class='flag-5'>訪問</b><b class='flag-5'>控制</b>

    鴻蒙開發(fā)Ability Kit程序訪問控制:向用戶申請單次授權(quán)

    受限開放的權(quán)限通常是不允許三方應(yīng)用申請的。當(dāng)應(yīng)用在申請權(quán)限來訪問必要的資源時(shí),發(fā)現(xiàn)部分權(quán)限的等級比應(yīng)用APL等級高,開發(fā)者可以選擇通過ACL方式來解決等級不匹配的問題,從而使用受限權(quán)限。
    的頭像 發(fā)表于 07-02 17:48 ?509次閱讀
    <b class='flag-5'>鴻蒙</b><b class='flag-5'>開發(fā)</b><b class='flag-5'>Ability</b> <b class='flag-5'>Kit</b><b class='flag-5'>程序</b><b class='flag-5'>訪問</b><b class='flag-5'>控制</b>:向用戶申請單次授權(quán)

    鴻蒙開發(fā)Ability Kit程序訪問控制:申請使用受限權(quán)限

    受限開放的權(quán)限通常是不允許三方應(yīng)用申請的。當(dāng)應(yīng)用在申請權(quán)限來訪問必要的資源時(shí),發(fā)現(xiàn)部分權(quán)限的等級比應(yīng)用APL等級高,開發(fā)者可以選擇通過ACL方式來解決等級不匹配的問題,從而使用受限權(quán)限。
    的頭像 發(fā)表于 07-02 17:34 ?455次閱讀
    <b class='flag-5'>鴻蒙</b><b class='flag-5'>開發(fā)</b><b class='flag-5'>Ability</b> <b class='flag-5'>Kit</b><b class='flag-5'>程序</b><b class='flag-5'>訪問</b><b class='flag-5'>控制</b>:申請使用受限權(quán)限

    鴻蒙開發(fā)Ability Kit程序訪問控制:對所有應(yīng)用開放

    在申請目標(biāo)權(quán)限前,建議開發(fā)者先閱讀[申請應(yīng)用權(quán)限],對權(quán)限的工作流程有基本了解后,再結(jié)合以下權(quán)限字段的具體說明,判斷應(yīng)用能否申請目標(biāo)權(quán)限,提高開發(fā)效率。
    的頭像 發(fā)表于 07-02 14:32 ?467次閱讀
    <b class='flag-5'>鴻蒙</b><b class='flag-5'>開發(fā)</b><b class='flag-5'>Ability</b> <b class='flag-5'>Kit</b><b class='flag-5'>程序</b><b class='flag-5'>訪問</b><b class='flag-5'>控制</b>:對所有應(yīng)用開放

    鴻蒙開發(fā)Ability Kit程序訪問控制:安全控件概述

    安全控件是系統(tǒng)提供的一組系統(tǒng)實(shí)現(xiàn)的ArkUI組件,應(yīng)用集成這類組件就可以實(shí)現(xiàn)在用戶點(diǎn)擊后自動(dòng)授權(quán),而無需彈窗授權(quán)。它們可以作為一種“特殊的按鈕”融入應(yīng)用頁面,實(shí)現(xiàn)用戶點(diǎn)擊即許可的設(shè)計(jì)思路。
    的頭像 發(fā)表于 07-03 09:22 ?414次閱讀
    <b class='flag-5'>鴻蒙</b><b class='flag-5'>開發(fā)</b><b class='flag-5'>Ability</b> <b class='flag-5'>Kit</b><b class='flag-5'>程序</b><b class='flag-5'>訪問</b><b class='flag-5'>控制</b>:安全<b class='flag-5'>控件</b>概述

    鴻蒙開發(fā)Ability Kit程序訪問控制:使用粘貼控件

    粘貼控件是一種特殊的系統(tǒng)安全控件,它允許應(yīng)用在用戶的授權(quán)下無提示地讀取剪貼板數(shù)據(jù)。
    的頭像 發(fā)表于 07-03 09:15 ?318次閱讀
    <b class='flag-5'>鴻蒙</b><b class='flag-5'>開發(fā)</b><b class='flag-5'>Ability</b> <b class='flag-5'>Kit</b><b class='flag-5'>程序</b><b class='flag-5'>訪問</b><b class='flag-5'>控制</b>:使用粘貼<b class='flag-5'>控件</b>

    鴻蒙開發(fā)Ability Kit程序訪問控制:使用位置控件

    位置控件使用直觀且易懂的通用標(biāo)識,讓用戶明確地知道這是一個(gè)獲取位置信息的按鈕。這滿足了授權(quán)場景需要匹配用戶真實(shí)意圖的需求。只有當(dāng)用戶主觀愿意,并且明確了解使用場景后點(diǎn)擊位置控件,應(yīng)用才會(huì)獲得臨時(shí)的授權(quán),獲取位置信息并完成相應(yīng)的服務(wù)功能。
    的頭像 發(fā)表于 07-03 16:32 ?401次閱讀
    <b class='flag-5'>鴻蒙</b><b class='flag-5'>開發(fā)</b><b class='flag-5'>Ability</b> <b class='flag-5'>Kit</b><b class='flag-5'>程序</b><b class='flag-5'>訪問</b><b class='flag-5'>控制</b>:使用位置<b class='flag-5'>控件</b>