【错误记录】Android 分区存储 错误 ( 文件格式不匹配 )
生活随笔
收集整理的這篇文章主要介紹了
【错误记录】Android 分区存储 错误 ( 文件格式不匹配 )
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
文章目錄
- 一、報錯信息
- 二、解決方案
一、報錯信息
Android 分區存儲 , 將 圖片文件 保存到 Movies 目錄下報錯 :
2021-05-18 14:31:50.691 1341-5448/com.google.android.providers.media.module E/DatabaseUtils: Writing exception to parceljava.lang.IllegalArgumentException: Primary directory Movies not allowed for content://media/external/images/media; allowed directories are [DCIM, Pictures]at com.android.providers.media.MediaProvider.ensureFileColumns(MediaProvider.java:2682)at com.android.providers.media.MediaProvider.ensureUniqueFileColumns(MediaProvider.java:2347)at com.android.providers.media.MediaProvider.insertFile(MediaProvider.java:2957)at com.android.providers.media.MediaProvider.insertInternal(MediaProvider.java:3361)at com.android.providers.media.MediaProvider.insert(MediaProvider.java:3208)at android.content.ContentProvider$Transport.insert(ContentProvider.java:336)at android.content.ContentProviderNative.onTransact(ContentProviderNative.java:167)at android.os.Binder.execTransactInternal(Binder.java:1154)at android.os.Binder.execTransact(Binder.java:1123) 2021-05-18 14:31:50.695 6361-6361/kim.hsl.file E/AndroidRuntime: FATAL EXCEPTION: mainProcess: kim.hsl.file, PID: 6361java.lang.RuntimeException: Unable to start activity ComponentInfo{kim.hsl.file/kim.hsl.file.MainActivity}: java.lang.IllegalArgumentException: Primary directory Movies not allowed for content://media/external/images/media; allowed directories are [DCIM, Pictures]at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:3449)at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:3601)at android.app.servertransaction.LaunchActivityItem.execute(LaunchActivityItem.java:85)at android.app.servertransaction.TransactionExecutor.executeCallbacks(TransactionExecutor.java:135)at android.app.servertransaction.TransactionExecutor.execute(TransactionExecutor.java:95)at android.app.ActivityThread$H.handleMessage(ActivityThread.java:2066)at android.os.Handler.dispatchMessage(Handler.java:106)at android.os.Looper.loop(Looper.java:223)at android.app.ActivityThread.main(ActivityThread.java:7656)at java.lang.reflect.Method.invoke(Native Method)at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:592)at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:947)Caused by: java.lang.IllegalArgumentException: Primary directory Movies not allowed for content://media/external/images/media; allowed directories are [DCIM, Pictures]at android.database.DatabaseUtils.readExceptionFromParcel(DatabaseUtils.java:172)at android.database.DatabaseUtils.readExceptionFromParcel(DatabaseUtils.java:142)at android.content.ContentProviderProxy.insert(ContentProviderNative.java:549)at android.content.ContentResolver.insert(ContentResolver.java:2149)at android.content.ContentResolver.insert(ContentResolver.java:2111)at kim.hsl.file.MainActivity.createImageFile(MainActivity.kt:116)at kim.hsl.file.MainActivity.doSomethingWithPermissions(MainActivity.kt:41)at kim.hsl.file.MainActivity.onCreate(MainActivity.kt:24)at android.app.Activity.performCreate(Activity.java:8000)at android.app.Activity.performCreate(Activity.java:7984)at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1309)at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:3422)at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:3601) at android.app.servertransaction.LaunchActivityItem.execute(LaunchActivityItem.java:85) at android.app.servertransaction.TransactionExecutor.executeCallbacks(TransactionExecutor.java:135) at android.app.servertransaction.TransactionExecutor.execute(TransactionExecutor.java:95) at android.app.ActivityThread$H.handleMessage(ActivityThread.java:2066) at android.os.Handler.dispatchMessage(Handler.java:106) at android.os.Looper.loop(Looper.java:223) at android.app.ActivityThread.main(ActivityThread.java:7656) at java.lang.reflect.Method.invoke(Native Method) at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:592) at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:947) 2021-05-18 14:31:50.797 321-321/? E/Layer: [Surface(name=Task=44)/@0x35761af - animation-leash#0] No local sync point found 2021-05-18 14:31:50.797 321-321/? E/Layer: [Surface(name=Task=1)/@0xe9c7852 - animation-leash#0] No local sync point found
二、解決方案
在 Android 111111 之后 , 不能使用 File 進行文件操作 , 需要使用 MediaStore 進行文件操作 ,
MediaStore 的如下內部類 Files , Images , Downloads , Audio , Video , 負責相應目錄的文件操作 , 分別對應外置存儲中的 Document , Pictures , Download , Music , Movies 目錄 ;
對應格式的文件 , 只能放在特定的目錄中 ;
文件存儲類型限制 : 文件一旦放錯位置 , 就會拋異常 ;
-
專門存儲 圖片文件 的目錄 Pictures , 只能存放圖片 , 不能存放其它類型文件 ,
-
專門存儲 視頻文件 的目錄 Movies , 只能存視頻文件 ;
-
專門存儲音頻文件的目錄 Music , 只能存儲音頻文件 ;
-
專門存儲文檔文件的目錄 Document , 只能存儲文檔相關文件 ;
-
Download 目錄可以放置任何類型的文件 ;
總結
以上是生活随笔為你收集整理的【错误记录】Android 分区存储 错误 ( 文件格式不匹配 )的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 【错误记录】Android 文件查看错误
- 下一篇: 【错误记录】Android 文件分享 F