requires android.permission.READ_EXTERNAL_STORAGE, or grantUriPermission()

在我的nexus 5上,

有这样的一个报错:

03-15 20:05:10.400: E/MainActivity(28711): java.lang.SecurityException: Permission Denial: reading com.android.providers.media.MediaProvider uri content://media/external/video/media from pid=28711, uid=10084 requires android.permission.READ_EXTERNAL_STORAGE, or grantUriPermission()

03-15 20:05:10.400: E/MainActivity(28711): at android.os.Parcel.readException(Parcel.java:1465)
03-15 20:05:10.400: E/MainActivity(28711): at android.database.DatabaseUtils.readExceptionFromParcel(DatabaseUtils.java:185)
03-15 20:05:10.400: E/MainActivity(28711): at android.database.DatabaseUtils.readExceptionFromParcel(DatabaseUtils.java:137)
03-15 20:05:10.400: E/MainActivity(28711): at android.content.ContentProviderProxy.query(ContentProviderNative.java:413)
03-15 20:05:10.400: E/MainActivity(28711): at android.content.ContentResolver.query(ContentResolver.java:461)



我在4.4.2的开发者选项里头没有找到下文提到的保护的选项。于是:


在AndroidManifest.xml中,加入这句话:

<uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE" />


就ok了。


=============================================

参考  http://blog.chengyunfeng.com/?p=427


JellyBean中的READ_EXTERNAL_STORAGE权限

作者: rain 分类: 移动 发布时间: 2012-07-26 20:12 ė 6没有评论

在JellyBean中,Android添加了一个新的权限”android.permission.READ_EXTERNAL_STORAGE”,顾名思义该权限说明该程序可以读取设备外部存储空间(内置SDcard和外置SDCard)的文件,如果您的App已经添加了“WRITE_EXTERNAL_STORAGE ”权限 ,则就没必要添加读的权限了,写权限已经包含了读权限了。

而对于那些既没有写权限也没有设置这个新的读权限的App,在Jelly Bean之前的版本中读取SDCard中的内存是没问题的,而在新的JellyBean的设置选项中Google新添加了一个设置项:“对USB存储设备进行读写保护”,如果用户启用了该选项,则没有添加”android.permission.READ_EXTERNAL_STORAGE”或者“WRITE_EXTERNAL_STORAGE ”权限的App是不能读取SDCard中文件的。

4.1的模拟器目前没有读取系统的设置项内存,所以该问题在模拟器上是测试不出来的。

如果您的App没有直接读取SDcard中的文件,而是处理从Intent或者ContentProvider中获取的URI,由于URI可能指向一个文件,所以这种情况您也需要添加该读权限,例如(使用 ContentResolver来打开一个 file:// Uri )

如果您的App提供了ContentProvider,则您应该暴露 content:// Uri给第三方程序使用(而不是 file:// Uri), 第三方程序在使用content:// Uri访问SDCard中的文件内容的时候 是通过您的ContentProvider来打开文件的,这样使用您的App的软件就无需添加读文件的权限了。

下图是Jelly Bean中对USB读写保护的设置项截图,注意在确认对话框中 提示可能会导致没有读写权限的App无法读取SDcard中的内容:



Read more: http://blog.chengyunfeng.com/?p=427#ixzz2w27Ncr5x




发布了652 篇原创文章 · 获赞 55 · 访问量 217万+
展开阅读全文

关于Android的错误:Permission Denial: 。。。.READ_EXTERNAL_STORAGE, or grantUriPermission(

10-11

这是错误代码 ,在虚拟机运行时崩溃, E/AndroidRuntime: FATAL EXCEPTION: main Process: com.add.mp3list, PID: 7193 java.lang.RuntimeException: Unable to start activity ComponentInfo{com.add.mp3list/com.add.mp3list.MainActivity}: java.lang.SecurityException: Permission Denial: reading com.android.providers.media.MediaProvider uri content://media/external/audio/media from pid=7193, uid=10090 requires android.permission.READ_EXTERNAL_STORAGE, or grantUriPermission() at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2817) at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2892) at android.app.ActivityThread.-wrap11(Unknown Source:0) at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1593) at android.os.Handler.dispatchMessage(Handler.java:105) at android.os.Looper.loop(Looper.java:164) at android.app.ActivityThread.main(ActivityThread.java:6541) at java.lang.reflect.Method.invoke(Native Method) at com.android.internal.os.Zygote$MethodAndArgsCaller.run(Zygote.java:240) at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:767) Caused by: java.lang.SecurityException: Permission Denial: reading com.android.providers.media.MediaProvider uri content://media/external/audio/media from pid=7193, uid=10090 requires android.permission.READ_EXTERNAL_STORAGE, or grantUriPermission() at android.os.Parcel.readException(Parcel.java:1942) at android.database.DatabaseUtils.readExceptionFromParcel(DatabaseUtils.java:183) at android.database.DatabaseUtils.readExceptionFromParcel(DatabaseUtils.java:135) at android.content.ContentProviderProxy.query(ContentProviderNative.java:418) at android.content.ContentResolver.query(ContentResolver.java:754) at android.content.ContentResolver.query(ContentResolver.java:704) at android.content.ContentResolver.query(ContentResolver.java:662) at com.add.mp3list.MusicList.getMusicData(MusicList.java:26) at com.add.mp3list.MainActivity.onCreate(MainActivity.java:21) at android.app.Activity.performCreate(Activity.java:6975) at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1213) at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2770) at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2892)  at android.app.ActivityThread.-wrap11(Unknown Source:0)  at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1593)  at android.os.Handler.dispatchMessage(Handler.java:105)  at android.os.Looper.loop(Looper.java:164)  at android.app.ActivityThread.main(ActivityThread.java:6541)  at java.lang.reflect.Method.invoke(Native Method)  at com.android.internal.os.Zygote$MethodAndArgsCaller.run(Zygote.java:240)  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:767)  Application terminated. 问答

Android Media数据库出错

08-07

开机启动音乐后,加载上次播放列表,并播放上次记录的音乐,在setDataSource播放的时候出错。Logcat如下: 25.675 E/DatabaseUtils( 695): java.lang.NullPointerException 01-01 02:22:25.675 E/DatabaseUtils( 695): at java.io.File.fixSlashes(File.java:185) 01-01 02:22:25.675 E/DatabaseUtils( 695): at java.io.File.<init>(File.java:134) 01-01 02:22:25.675 E/DatabaseUtils( 695): at com.android.providers.media.MediaProvider.queryForDataFile(MediaProvider.java:4734) 01-01 02:22:25.675 E/DatabaseUtils( 695): at com.android.providers.media.MediaProvider.openFileAndEnforcePathPermissionsHelper(MediaProvider.java:4754) 01-01 02:22:25.675 E/DatabaseUtils( 695): at com.android.providers.media.MediaProvider.openFile(MediaProvider.java:4680) 01-01 02:22:25.675 E/DatabaseUtils( 695): at android.content.ContentProvider.openAssetFile(ContentProvider.java:1213) 01-01 02:22:25.675 E/DatabaseUtils( 695): at android.content.ContentProvider.openTypedAssetFile(ContentProvider.java:1393) 01-01 02:22:25.675 E/DatabaseUtils( 695): at android.content.ContentProvider.openTypedAssetFile(ContentProvider.java:1459) 01-01 02:22:25.675 E/DatabaseUtils( 695): at android.content.ContentProvider$Transport.openTypedAssetFile(ContentProvider.java:342) 01-01 02:22:25.675 E/DatabaseUtils( 695): at android.content.ContentProviderNative.onTransact(ContentProviderNative.java:305) 01-01 02:22:25.675 E/DatabaseUtils( 695): at android.os.Binder.execTransact(Binder.java:404) 01-01 02:22:25.675 E/DatabaseUtils( 695): at dalvik.system.NativeStart.run(Native Method) 01-01 02:22:25.675 E/MediaPlaybackService( 995): mPlayer.setDataSource 01-01 02:22:25.675 W/System.err( 995): java.lang.NullPointerException 01-01 02:22:25.675 W/System.err( 995): at android.os.Parcel.readException(Parcel.java:1471) 01-01 02:22:25.675 W/System.err( 995): at android.database.DatabaseUtils.readExceptionFromParcel(DatabaseUtils.java:185) 01-01 02:22:25.675 W/System.err( 995): at android.database.DatabaseUtils.readExceptionWithFileNotFoundExceptionFromParcel(DatabaseUtils.java:148) 01-01 02:22:25.675 W/System.err( 995): at android.content.ContentProviderProxy.openTypedAssetFile(ContentProviderNative.java:682) 01-01 02:22:25.675 W/System.err( 995): at android.content.ContentResolver.openTypedAssetFileDescriptor(ContentResolver.java:1063) 01-01 02:22:25.675 W/System.err( 995): at android.content.ContentResolver.openAssetFileDescriptor(ContentResolver.java:904) 01-01 02:22:25.675 W/System.err( 995): at android.content.ContentResolver.openAssetFileDescriptor(ContentResolver.java:831) 01-01 02:22:25.675 W/System.err( 995): at android.media.MediaPlayer.setDataSource(MediaPlayer.java:898) 01-01 02:22:25.675 W/System.err( 995): at android.media.MediaPlayer.setDataSource(MediaPlayer.java:874) 01-01 02:22:25.675 W/System.err( 995): at com.android.newmusic.MediaPlaybackService$MultiPlayer.setDataSourceImpl(MediaPlaybackService.java:2213) 01-01 02:22:25.675 W/System.err( 995): at com.android.newmusic.MediaPlaybackService$MultiPlayer.setDataSource(MediaPlaybackService.java:2200) 01-01 02:22:25.675 W/System.err( 995): at com.android.newmusic.MediaPlaybackService.open(MediaPlaybackService.java:1396) 01-01 02:22:25.675 W/System.err( 995): at com.android.newmusic.MediaPlaybackService.openCurrentAndNext(MediaPlaybackService.java:1280) 01-01 02:22:25.675 W/System.err( 995): at com.android.newmusic.MediaPlaybackService.reloadQueue(MediaPlaybackService.java:700) 01-01 02:22:25.675 W/System.err( 995): at com.android.newmusic.MediaPlaybackService.onCreate(MediaPlaybackService.java:444) 01-01 02:22:25.675 W/System.err( 995): at android.app.ActivityThread.handleCreateService(ActivityThread.java:2558) 01-01 02:22:25.675 W/System.err( 995): at android.app.ActivityThread.access$1800(ActivityThread.java:135) 01-01 02:22:25.675 W/System.err( 995): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1278) 01-01 02:22:25.675 W/System.err( 995): at android.os.Handler.dispatchMessage(Handler.java:102) 01-01 02:22:25.675 W/System.err( 995): at android.os.Looper.loop(Looper.java:136) 01-01 02:22:25.675 W/System.err( 995): at android.app.ActivityThread.main(ActivityThread.java:5001) 01-01 02:22:25.675 W/System.err( 995): at java.lang.reflect.Method.invokeNative(Native Method) 01-01 02:22:25.675 W/System.err( 995): at java.lang.reflect.Method.invoke(Method.java:515) 01-01 02:22:25.675 W/System.err( 995): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:801) 01-01 02:22:25.675 W/System.err( 995): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:617) 01-01 02:22:25.675 W/System.err( 995): at dalvik.system.NativeStart.main(Native Method) 01-01 02:22:25.675 D/MediaPlaybackService( 995): Failed to open file for playback 问答

没有更多推荐了,返回首页

©️2019 CSDN 皮肤主题: 大白 设计师: CSDN官方博客

分享到微信朋友圈

×

扫一扫,手机浏览