Android创建文件时出现java.io.IOException: Operation not permitted异常的解决方法
作者:老杜_d
一、android 6.0
6.0之前是不需要动态申请权限的,直接在manifest.xml中申请即可以正常使用。
<uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE" /> <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
二、安卓10,SDK=29
安卓10开始,安卓继续加强了限制,如果需要读写SD卡,还需要额外的进行申请requestLegacyExternalStorage申明。
<application android:name=".common.base.BaseApplication" android:allowBackup="true" android:icon="@mipmap/logo" android:label="@string/app_name" android:largeHeap="true" android:requestLegacyExternalStorage="true" //添加这一行 android:roundIcon="@mipmap/logo" android:supportsRtl="true" android:theme="@style/AppTheme" android:usesCleartextTraffic="true" tools:replace="android:icon,android:roundIcon">
三、安卓11,SDK=30
安卓11的时候继续强化对SD卡读写的管理,引入了MANAGE_EXTERNAL_STORAGE权限,而之前的WRITE_EXTERNAL_STORAGE已经失效了。
并且MANAGE_EXTERNAL_STORAGE权限只能跳转设置页面申请。
四、安卓13,SDK=33
android 13上,取消了android.permission.WRITE_EXTERNAL_STORAGE权限,只需要申android.permission.MANAGE_EXTERNAL_STORAGE权限。
以下是我遇到的问题分析:
创建文件时,一直报Operation not permitted异常,没有权限。但是我在代码里把以上权限完全开启了。而且android 11虽然开启了强制分区存储,但是只针对 targetSDK>=30的情况,而我的应用targetSDK版本为29。
后来发现是我的文件名使用当前时间来命名(2023-2-10 15:38:45),而当前时间里带有 “:”,导致文件创建权限不足。
许多的字符都属于公共空间文件的不合法字符(如上图),但是在私有空间是没有这个问题的。可能是由于在公有空间和私有空间访问走的是两套机制。公有空间会走MediaStore,私有空间并不会。
我们在android 11系统的手机上,手动创建文件时,文件名也不能包含这些字符。android 10 之前就没有发现这个问题。
所以问题的解决方法有两种:
1、把文件放到私有空间(即内存)中
2、修改文件名,避免特殊字符
总结
到此这篇关于Android创建文件时出现java.io.IOException: Operation not permitted异常解决的文章就介绍到这了,更多相关java.io.IOException: Operation not permitted异常内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
您可能感兴趣的文章:
- 解决springboot报错Failed to parse multipart servlet request; nested exception is java.io.IOException问题
- 什么情况下会出现java.io.IOException : Broken pipe这个错误以及解决办法
- 解决Spring调用Feign报错:java.io.IOException:Incomplete output stream问题
- java.io.IOException: UT010029: Stream is closed异常分析及解决
- java.io.IOException:你的主机中的软件中止了一个已建立的连接踩坑实战
- 解决Java中的java.io.IOException: Broken pipe问题
- AndroidApk混淆编译时,报告java.io.IOException...错误解决办法
- JSP上传图片产生 java.io.IOException: Stream closed异常解决方法
- Caused by: java.io.IOException: DerInputStream.getLength(): lengthTag=111