FileProvider使用以及源码浅析

简介: FileProvider使用以及源码浅析

1. FileProvider的使用


1.1 AndroidManifest.xml中定义

 <provider
            android:name="android.support.v4.content.FileProvider"
            android:authorities="com.peter.jiangbin.fileprovider"
            android:exported="false"
            android:grantUriPermissions="true">
            <meta-data
                android:name="android.support.FILE_PROVIDER_PATHS"
                android:resource="@xml/file_paths" />
</provider>

1.2 res目录下新建xml/file_paths.xml

<?xml version="1.0" encoding="utf-8"?>
<resources>
    <paths>
        <root-path name="rp" path="jiangbin"/>
        <files-path name="fp" path="jiangbin"/>
        <cache-path name="cp" path="jiangbin" />
        <external-path name="ep" path="jiangbin"/>
        <external-files-path name="efp" path="jiangbin" />
        <external-cache-path name="ecp" path="jiangbin" />
    </paths>
</resources>

1.3 用FileProvider.getUriForFile(Context context, String authority, File file)取代Uri.fromFile(File file)

 File file = new File(mContext.getFilesDir() + "/jiangbin", "hello.txt");
        Uri data;
        if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.N) {
            data = FileProvider.getUriForFile(mContext, "com.ysx.fileproviderserver.fileprovider", file);
        } else {
            data = Uri.fromFile(file);
        }

1.4 赋予临时权限2. TAG与文件路径对应关系表

intent.addFlags(Intent.FLAG_GRANT_READ_URI_PERMISSION | FLAG_GRANT_WRITE_URI_PERMISSION);

2. TAG与文件路径对应关系表


image.png

3. 源码浅析



3.1 配置FileProvider,做了什么


我们来看下源码

public class FileProvider extends ContentProvider {
    ...
    @GuardedBy("sCache")
    private static HashMap<String, PathStrategy> sCache = new HashMap<String, PathStrategy>();
    interface PathStrategy {
        public Uri getUriForFile(File file);
        public File getFileForUri(Uri uri);
    }
    static class SimplePathStrategy implements PathStrategy {
        private final String mAuthority;
        private final HashMap<String, File> mRoots = new HashMap<String, File>();
        public SimplePathStrategy(String authority) {
            mAuthority = authority;
        }
    }
    ...
}

我们注意到源码中有两个HashMap。第一个是static HashMap


3.1 配置FileProvider的本质是什么

我们经常用到文件Uri的场景就是APP启动安装程序界面,并传递安装文件的路径给安装程序。在Android7.0之后。程序A想要使用程序B中的文件Uri。那么程序B必须将文件路径的策略注册到FileProvider的sCache中,并且FileProvider提供了根据Uri反向解码文件路径的功能


相关文章
|
8月前
|
编译器 Android开发
Android S内置APK时AndroidManifest使用uses-library编译报错
Android S内置APK时AndroidManifest使用uses-library编译报错
337 0
|
8月前
|
Java Android开发
Android 反编译工具的使用
Android 反编译工具的使用
94 0
|
XML Java Android开发
Android 反编译工具
Android 反编译工具
137 0
|
存储 前端开发 Java
Android ClassLoader 源码阅读
Android ClassLoader 源码阅读
|
文字识别 Java 开发工具
Android 使用so库的遇到的坑
Android 使用so库的遇到的坑
622 0
Android 使用so库的遇到的坑
|
Android开发 Java
Android Volley.jar包下载
Android Volley下载 Android Volley是Android平台上很好用的第三方开源网络通信框架。使用简答,功能强大。
1761 0
|
存储 Android开发
【错误记录】Android 文件分享 FileProvider 设置错误
【错误记录】Android 文件分享 FileProvider 设置错误
220 0
【错误记录】Android 文件分享 FileProvider 设置错误
|
安全 Java Android开发
【Android 安全】DEX 加密 ( 常用 Android 反编译工具 | apktool | dex2jar | enjarify | jd-gui | jadx )(二)
【Android 安全】DEX 加密 ( 常用 Android 反编译工具 | apktool | dex2jar | enjarify | jd-gui | jadx )(二)
441 0
【Android 安全】DEX 加密 ( 常用 Android 反编译工具 | apktool | dex2jar | enjarify | jd-gui | jadx )(二)
|
安全 Java Android开发
【Android 安全】DEX 加密 ( 常用 Android 反编译工具 | apktool | dex2jar | enjarify | jd-gui | jadx )(一)
【Android 安全】DEX 加密 ( 常用 Android 反编译工具 | apktool | dex2jar | enjarify | jd-gui | jadx )(一)
502 0
【Android 安全】DEX 加密 ( 常用 Android 反编译工具 | apktool | dex2jar | enjarify | jd-gui | jadx )(一)
|
安全 Android开发 索引
Android dex文件解析
1. 关于Android dex文件 dex文件作为Android APK的组成部分,其主要是Android的Java代码经过编译生成class文件,再经过dx命令生成的。
1056 0