【错误记录】Android 低版本使用分区存储错误 ( 低版本存储不得使用 MediaStore )
2023-06-13 09:17:50 时间
文章目录
Android 低版本系统中不能使用分区存储方式管理文件 ;
一、报错信息
在 Android 9 版本中使用 MediaStore 进行分区存储 ;
/**
* 创建文件
* 在 Download 目录下创建 hello.txt
*/
fun createFile(){
// 操作 external.db 数据库
// 获取 Uri 路径
var uri: Uri = MediaStore.Files.getContentUri("external")
// 将要新建的文件的文件索引插入到 external.db 数据库中
// 需要插入到 external.db 数据库 files 表中, 这里就需要设置一些描述信息
var contentValues: ContentValues = ContentValues()
// 设置插入 external.db 数据库中的 files 数据表的各个字段的值
// 设置存储路径 , files 数据表中的对应 relative_path 字段在 MediaStore 中以常量形式定义
contentValues.put(MediaStore.Downloads.RELATIVE_PATH, "${Environment.DIRECTORY_DOWNLOADS}/hello")
// 设置文件名称
contentValues.put(MediaStore.Downloads.DISPLAY_NAME, "hello.txt")
// 设置文件标题, 一般是删除后缀, 可以不设置
contentValues.put(MediaStore.Downloads.TITLE, "hello")
// uri 表示操作哪个数据库 , contentValues 表示要插入的数据内容
var insert: Uri = contentResolver.insert(uri, contentValues)!!
// 向 Download/hello/hello.txt 文件中插入数据
var os: OutputStream = contentResolver.openOutputStream(insert)!!
var bos = BufferedOutputStream(os)
bos.write("Hello World".toByteArray())
bos.close()
}
报错信息 :
2021-05-18 11:53:49.339 5599-5627/kim.hsl.file E/libc: Access denied finding property "vendor.debug.egl.profiler"
2021-05-18 11:53:49.518 5599-5599/kim.hsl.file E/AndroidRuntime: FATAL EXCEPTION: main
Process: kim.hsl.file, PID: 5599
java.lang.RuntimeException: Unable to start activity ComponentInfo{kim.hsl.file/kim.hsl.file.MainActivity}: java.lang.IllegalArgumentException: no path was provided when inserting new file
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2951)
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:3086)
at android.app.servertransaction.LaunchActivityItem.execute(LaunchActivityItem.java:78)
at android.app.servertransaction.TransactionExecutor.executeCallbacks(TransactionExecutor.java:108)
at android.app.servertransaction.TransactionExecutor.execute(TransactionExecutor.java:68)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1816)
at android.os.Handler.dispatchMessage(Handler.java:106)
at android.os.Looper.loop(Looper.java:193)
at android.app.ActivityThread.main(ActivityThread.java:6718)
at java.lang.reflect.Method.invoke(Native Method)
at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:493)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:858)
Caused by: java.lang.IllegalArgumentException: no path was provided when inserting new file
at android.database.DatabaseUtils.readExceptionFromParcel(DatabaseUtils.java:165)
at android.database.DatabaseUtils.readExceptionFromParcel(DatabaseUtils.java:135)
at android.content.ContentProviderProxy.insert(ContentProviderNative.java:476)
at android.content.ContentResolver.insert(ContentResolver.java:1588)
at kim.hsl.file.MainActivity.createFile(MainActivity.kt:76)
at kim.hsl.file.MainActivity.doSomethingWithPermissions(MainActivity.kt:37)
at kim.hsl.file.MainActivity.onCreate(MainActivity.kt:23)
at android.app.Activity.performCreate(Activity.java:7144)
at android.app.Activity.performCreate(Activity.java:7135)
at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1271)
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2931)
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:3086)
at android.app.servertransaction.LaunchActivityItem.execute(LaunchActivityItem.java:78)
at android.app.servertransaction.TransactionExecutor.executeCallbacks(TransactionExecutor.java:108)
at android.app.servertransaction.TransactionExecutor.execute(TransactionExecutor.java:68)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1816)
at android.os.Handler.dispatchMessage(Handler.java:106)
at android.os.Looper.loop(Looper.java:193)
at android.app.ActivityThread.main(ActivityThread.java:6718)
at java.lang.reflect.Method.invoke(Native Method)
at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:493)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:858)
二、解决方案
没有解决方案 , 在 Android 11 及以上的版本中使用分区存储 ;
在 Android 10 及以下的版本中 , 使用普通的存储方式 ;
访问外置 SD 卡 必须开发两套存储方式 去兼容 分区存储 及 之前的版本 ;
Android 10 过渡版本中 , 可以选择使用分区存储方式 , 也可以选择使用之前的存储方式 ;
Android 10 版本是过渡版本 , 在该版本中可以选择启用分区存储 , 也可以选择不用 , 在清单文件的 application 节点设置 requestLegacyExternalStorage=“true” 属性可以设置 不启用 分区存储 方案 , 但是 在 Android 11 中 必须 启用分区存储 , 否则应用不能兼容 Android 11 系统 ;
相关文章
- Android adb install 命令安装apk
- android vlc 中文字幕,解决Android版vlc中文乱码问题
- robotium android,Robotium 测试Android apk安装包
- Android 编译C++
- Unity+Android GET和POST方式的简单实现API请求(人像动漫化)
- android的toast提示_android studio unknown host
- android toast的用法_toast 安卓
- Android RecyclerView使用简述
- Android Jetpack Compose 动画速查表
- android scaleanimation动画,Android 动画之ScaleAnimation应用详解「建议收藏」
- android 终端模拟器
- 【Android RTMP】NV21 图像旋转处理 ( 图像旋转算法 | 后置摄像头顺时针旋转 90 度 | 前置摄像头顺时针旋转 90 度 )
- 【错误记录】Android 应用 release 打包报错处理 ( 关闭语法检查 | 日志处理 | release 配置 )
- 【Android 事件分发】事件分发源码分析 ( ViewGroup 事件传递机制 三 )
- 【错误记录】Android Studio 编译报错 ( cannot open this project, please retry with version 4.2 or newer. )
- 【错误记录】Android 应用中启动 FlutterActivity 报错 ( have you declared this activity in your AndroidManifest )
- 【错误记录】Android Studio 编译报错 ( Could not find com.android.tools.build:gradle:4.2.1. )
- 【Android 逆向】x86 CPU 架构体系 ( CPU 模型 | 内存模型 )
- 【错误记录】记录 Android 命令行执行 Java 程序中出现的错误 ( dx 打包 PC 可执行文件报错 | dalvik 命令执行 kotlin 编译的 dex 文件报错 )
- 【错误记录】Android 应用安装后出现两个启动图标 ( 排查应用及依赖库中配置了 android.intent.category.LAUNCHER 的 Activity )
- 【错误记录】编译 Android 版本的 ijkplayer 报错 ( You must define ANDROID_NDK before starting. | 下载指定版本 NDK )
- Android开发中遇到的问题(三)——eclipse创建android项目无法正常预览布局文件详解手机开发
- Surface Duo将于9月或10月升级Android 11系统 Duo 2届时也将推出
- 超过20%用户仍在使用Android第三方ROM
- android自定义Android菜单背景的代码
- Android使用Pull方法解析XML文件的方法
- Android之采用execSQL与rawQuery方法完成数据的添删改查操作详解
- 六款值得推荐的android(安卓)开源框架简介