欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Android?FileProvider使用教程

 更新時(shí)間:2023年03月22日 17:25:40   作者:Dormiveglia-flx  
主要摘要關(guān)鍵知識(shí)點(diǎn)和記錄我的學(xué)習(xí)思路及驗(yàn)證結(jié)論,可以幫助讀者比較全面的認(rèn)識(shí)FileProvider,F(xiàn)ileProvider是特殊的ContentProvider,目標(biāo)是在為保護(hù)隱私和數(shù)據(jù)安全而加強(qiáng)應(yīng)用沙箱機(jī)制的同時(shí),支持在應(yīng)用間共享文件

Android基礎(chǔ)--FileProvider

Android 7.0之前,文件的Uri以file:///形式提供給其他app訪問。

Android 7.0之后,為了安全起見,file:///形式的Uri不能正常訪問,官方提 供了FileProvider,F(xiàn)ileProvider生成的Uri會(huì)以content://的形式分享給其他app使用。

那如何使用FileProvider?

在manifest 中聲明provider

	<provider
            android:authorities="${packagename}.provider"
            android:name="com.flx.cn.fileprovider"
            android:exported="false"
            android:grantUriPermissions="true">
            <meta-data
                android:name="android.support.FILE_PROVIDER_PATHS"
                android:resource="@xml/file_provider" />
	</provider>
  • authorities:相當(dāng)于一個(gè)用于認(rèn)證的暗號(hào),在分享文件生成Uri時(shí),會(huì)通過它的值生成對(duì)應(yīng)的Uri。
  • exported:的值為false,表示該FileProvider只能本應(yīng)用使用
  • meta-data:別的配置信息
  • grantUriPermissions:讓接收端的app臨時(shí)有權(quán)限進(jìn)行操作了。

設(shè)置共享目錄

<?xml version="1.0" encoding="utf-8"?>
<resources>
  <paths>
    <!--<root-path/> 代表設(shè)備的根目錄new File("/");-->
    <root-path
        name = ""
        path=""/>
    <!-- Context.getFilesDir() + "/path/" -->
    <files-path
        name="my_files"
        path="test/"/>
    <!-- Context.getCacheDir() + "/path/" -->
    <cache-path
        name="my_cache"
        path="test/"/>
    <!-- Context.getExternalFilesDir(null) + "/path/" -->
    <external-files-path
        name="external-files-path"
        path="test/"/>
    <!-- Context.getExternalCacheDir() + "/path/" -->
    <external-cache-path
         name="name"
         path="test/" />
    <!-- Environment.getExternalStorageDirectory() + "/path/" -->
    <external-path
        name="my_external_path"
        path="test/"/>
    <!-- Environment.getExternalStorageDirectory() + "/path/" -->
    <external-path
        name="files_root"
        path="Android/data/<包名>/"/>
    <!-- path設(shè)置為'.'時(shí)代表整個(gè)存儲(chǔ)卡 Environment.getExternalStorageDirectory() + "/path/"   -->
    <external-path
        name="external_storage_root"
        path="."/>
  </paths>
</resources>

最終生成的代碼效果

以第二個(gè)為例:
content://com.flx.cn.fileprovider/my_files/filexxx.jpg

生成Content Uri文件,供其他app使用

File filePath = new File(Context.getFilesDir(), "my_log");
File newFile = new File(filePath, "my_log.log");
// 生成Uri
Uri contentUri = FileProvider.getUriForFile(getContext(), "com.flx.cn.fileprovider", newFile);

授權(quán),一般就讀取和寫入2種權(quán)限,并分享

// 這里用的是發(fā)送文件。
Intent intent = new Intent(Intent.ACTION_SEND);
// 設(shè)置讀寫權(quán)限
intent.addFlags(Intent.FLAG_GRANT_READ_URI_PERMISSION | Intent.FLAG_GRANT_WRITE_URI_PERMISSION);
//Uri傳入Intent
intent.putExtra(Intent.EXTRA_STREAM, contentUri);
startActivity(intent)

到此這篇關(guān)于Android FileProvider使用教程的文章就介紹到這了,更多相關(guān)Android FileProvider內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

最新評(píng)論