共享文件
App经常需要提供一个或者是多个文件给其他的App。比如说,一个图片画廊可能会提供它们的图片给图片编辑器,或者是一个文件管理器App可能允许用户在外存区域间复制黏贴文件。其中一种发送可分享文件给App的方式是响应一个其他接收的App请求。
在所有情况下,唯一安全的从我们的App提供文件给其他App的方式是发送接收App文件内容的URI和临时授予访问权限URI。临时的URI访问权限的内容URI是安全的,因为它们只是应用于接收URI的App,而且它们自动失效。Android FileProvider 组件提供getUriForFile() 方法来产生文件的内容URI。
如果我们想要在App之间分享小量文本或者数值数据,我们应该发送一个包含这些数据(data)的Intent(这个就看那个分享简单数据的那个吧)。
现在要讲的是:如何使用通过Android FileProvider 组件产生的内容URI和我们同意内容URI的接收文件的App的临时权限,安全的从我们的App分享文件到另一个App。
设置文件共享
为了安全的从我们的App提供一个文件给另一个App,我们需要以一种内容URL的格式来配置我们的App来提供一个安全的处理的文件。Android FileProvider 组件基于我们在XML中特定声明来产生文件的content URI 。
注意!!!FileProvider 是v4支持包中才有的哦。。
指定FileProvider
要求在Manifest中定义一个FileProvider。
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="com.example.myapp">
<application
...>
<provider
android:name="android.support.v4.content.FileProvider"
android:authorities="com.example.myapp.fileprovider"
android:grantUriPermissions="true"
android:exported="false">
<meta-data
android:name="android.support.FILE_PROVIDER_PATHS"
android:resource="@xml/filepaths" />
</provider>
...
</application>
</manifest>
android:authorities 值是包名+fileprovider
<meta-data>
的子元素 <provider>
指向一个我们要分享的特定路径的xml文件, android:resource
属性是路径和没有.xml后缀的文件名。
指定可分享的路径
在这个文件中写着:res/xml/filepaths.xml
.
<paths>
<files-path path="images/" name="myimages" />
</paths>
这个例子中,
<files-path>
标签分享路径在 我们App内存储的
files/
路径中
path
属性分享的是
files/
子路径下的
images/路径
name 属性告诉 FileProvider 添加路径段 myimages 到content URI 到文件files/images/的子目录中
<paths>
元素可以有很多的子元素,除了这个<files-path>
元素之外,还可以使用<external-path>
元素共享外部存储, <cache-path>
可以分享内部缓存路径。
注意!!! XML文件是唯一可以指定分享路径的方式,不能代码添加路径的。。
如果我们请求的是一个文件名为default_image.jpg FileProvider会返回这样的URI:
content://com.example.myapp.fileprovider/myimages/default_image.jpg