Android开发:解决 Android N 上报错 android.os.FileUriExposedException: file:///storage/emulated/0/

解决android N文件访问crash android.os.FileUriExposedException file:///storage/emulated/0/xxx

 

原因:

Android N对访问文件权限收回,按照Android N的要求,若要在应用间共享文件,您应发送一项 content://URI,并授予 URI 临时访问权限。 
而进行此授权的最简单方式是使用 FileProvider类。

解决方法:

1.在mainfest.xml中加入FileProvider注册

<application>
 ......
     <provider
    android:name="android.support.v4.content.FileProvider"
    android:authorities="app的包名.fileProvider"
    android:grantUriPermissions="true"
    android:exported="false">
    <meta-data
        android:name="android.support.FILE_PROVIDER_PATHS"
        android:resource="@xml/file_paths" />
</provider>

</application>

注意: 
authorities:app的包名.fileProvider 
grantUriPermissions:必须是true,表示授予 URI 临时访问权限 
exported:必须是false 
resource:中的@xml/file_paths是我们接下来要添加的文件

2.配置filepaths文件

2-1.在res目录下新建一个xml文件夹,并且新建一个file_paths的xml文件(如下图)

2-2.打开file_paths.xml文件添加如下内容

<?xml version="1.0" encoding="utf-8"?>
<paths>
    <external-path path="Android/data/app的包名/" name="files_root" />
    <external-path path="." name="external_storage_root" />
</paths>

注:

path:需要临时授权访问的路径(.代表所有路径) 
name:就是你给这个访问路径起个名字

3.访问文件

 private static Uri getUriForFile(Context context, File file) {
        if (context == null || file == null) {
            throw new NullPointerException();
        }
        Uri uri;

//判断是否是AndroidN以及更高的版本
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.N) {//如果SDK版本>=24,即:Build.VERSION.SDK_INT >= 24
    uri = FileProvider.getUriForFile(context, BuildConfig.APPLICATION_ID + ".fileProvider", file);
} else {
    uri = Uri.fromFile(file);
}
        return uri;
    }

注:

a.首先我们对Android N及以上做判断; 
b.然后添加flags,表明我们要被授予什么样的临时权限 
c.以前我们直接 Uri.fromFile(file)构建出一个Uri,现在我们使用FileProvider.getUriForFile(context, BuildConfig.APPLICATION_ID + ".fileProvider", file); 
d.BuildConfig.APPLICATION_ID直接是应用的包名

 

 

  • 2
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
No content provider: /storage/emulated/0/517.png是指在Android应用程序中访问文件时出现的错误。 这个错误会在Android N版本及更高版本中出现,是因为Android引入了一项安全措施,限制了应用程序直接访问外部存储设备上的文件。这是为了保护用户的隐私和数据安全。 要解决这个问题,可以通过使用FileProvider来获取文件的内容URIFileProvider是Android提供的一个内容提供器,它允许应用程序共享文件给其他应用程序,并确保文件访问的安全性。你需要在你的应用程序的清单文件中配置FileProvider,并定义文件路径。一个常见的配置方式是使用一个XML文件来定义文件路径。 在你的应用程序的清单文件中添加以下内容: ``` <provider android:name="androidx.core.content.FileProvider" android:authorities="你的应用程序包名.fileprovider" android:exported="false" android:grantUriPermissions="true"> <meta-data android:name="android.support.FILE_PROVIDER_PATHS" android:resource="@xml/file_paths" /> </provider> ``` 然后,在res/xml目录下创建一个file_paths.xml文件,文件内容如下: ``` <?xml version="1.0" encoding="utf-8"?> <paths> <external-path name="external_files" path="." /> </paths> ``` 接下来,你需要修改你的代码,使用FileProvider获取文件的URI,如下所示: ```java File file = new File("/storage/emulated/0/517.png"); Uri fileUri = FileProvider.getUriForFile(context, "你的应用程序包名.fileprovider", file); ``` 现在你可以使用fileUri来传递给其他应用程序,确保文件访问的安全性,并且不会再出现No content provider的错误。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [Android开发解决 Android N 上报错 android.os.FileUriExposedException: file:///storage/emulated/0/](https://blog.csdn.net/android157/article/details/81609308)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *3* [android.os.FileUriExposedExceptionfile:///storage/emulated/0/test.txt通过Intent.getData()在应用...](https://blog.csdn.net/CHCH998/article/details/105509900)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值