java.lang.SecurityException: Permission Denial: reading com.android.providers.media.MediaProvider u

本文详细解析了java.lang.SecurityException异常,特别是当应用程序尝试读取外部存储而未正确请求READ_EXTERNAL_STORAGE权限时的情况。文章提供了错误堆栈跟踪,解释了为何需要手动启用此权限,并指导如何在应用中正确实现权限请求。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

java.lang.SecurityException: Permission Denial: reading com.android.providers.media.MediaProvider uri content://media/external/file from pid=30511, uid=10264 requires android.permission.READ_EXTERNAL_STORAGE, or grantUriPermission()
        at android.os.Parcel.createException(Parcel.java:1953)
        at android.os.Parcel.readException(Parcel.java:1921)
        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:816)
        at android.content.ContentResolver.query(ContentResolver.java:766)
        at android.content.ContentResolver.query(ContentResolver.java:717)
        at com.example.network.util.ApkUtil.getAllApkFile(ApkUtil.java:35)
        at com.example.network.activity.ApkInfoActivity.showApkList(ApkInfoActivity.java:66)
        at com.example.network.activity.ApkInfoActivity.access$000(ApkInfoActivity.java:35)
        at com.example.network.activity.ApkInfoActivity$1.run(ApkInfoActivity.java:59)
        at android.os.Handler.handleCallback(Handler.java:907)
        at android.os.Handler.dispatchMessage(Handler.java:105)
        at android.os.Looper.loop(Looper.java:216)
        at android.app.ActivityThread.main(ActivityThread.java:7625)
        at java.lang.reflect.Method.invoke(Native Method)
        at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:524)
        at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:987)

通过阅读可以知道是因为需要开启权限才能运行。原因是由于没有动态开启权限,需要手动去权限管理中开启申请的权限。

评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值