Android使用ContentProvider报异常(java.lang.SecurityException: Permission Denial: opening provider)

在使用ContentProvider时遇到`java.lang.SecurityException: Permission Denial`异常,问题出在manifest中provider节点的`exported`属性未设置为true。了解`exported`属性的作用,它是决定组件是否允许其他应用调用的关键。设置`exported=true`可解决这个问题,允许其他应用通过URI访问Provider。注意,API 17及以上版本默认值为false。

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

   具体错误日志如下:

01-17 17:25:46.497 20353-21018/ E/Tinker.UncaughtHandler: TinkerUncaughtHandler catch exception:java.lang.RuntimeException: An error occurred while executing doInBackground()
        at DF.done(PG:15)
        at java.util.concurrent.FutureTask.finishCompletion(FutureTask.java:354)
        at java.util.concurrent.FutureTask.setException(FutureTask.java:223)
        at java.util.concurrent.FutureTask.run(FutureTask.java:242)
        at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1113)
        at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:588)
        at java.lang.Thread.run(Thread.java:818)
     Caused by: java.lang.SecurityException: Permission Denial: opening provider com.android.providers.media.MediaDocumentsProvider from ProcessRecord{61e11e5 20353:/u0a191} (pid=20353, uid=10191) requires android.permission.MANAGE_DOCUMENTS or android.permission.MANAGE_DOCUMENTS
       
Failed to create session. An unknown server-side error occurred while processing the command. Original error: Error executing adbExec. Original error: 'Command 'D:\\tools\\platform-tools\\adb.exe -P 5037 -s e9ce79af shell 'settings delete global hidden_api_policy_pre_p_apps;settings delete global hidden_api_policy_p_apps;settings delete global hidden_api_policy'' exited with code 255'; Command output: Exception occurred while executing 'delete': java.lang.SecurityException: Permission denial, must have one of: [android.permission.WRITE_SECURE_SETTINGS] at com.android.providers.settings.SettingsProvider.enforceHasAtLeastOnePermission(SettingsProvider.java:2705) at com.android.providers.settings.SettingsProvider.mutateGlobalSetting(SettingsProvider.java:1610) at com.android.providers.settings.SettingsProvider.mutateGlobalSetting(SettingsProvider.java:1602) at com.android.providers.settings.SettingsProvider.deleteGlobalSetting(SettingsProvider.java:1573) at com.android.providers.settings.SettingsProvider.call(SettingsProvider.java:597) at android.content.ContentProvider.call(ContentProvider.java:2716) at android.content.ContentProvider$Transport.call(ContentProvider.java:641) at com.android.providers.settings.SettingsService$MyShellCommand.deleteForUser(SettingsService.java:411) at com.android.providers.settings.SettingsService$MyShellCommand.onCommand(SettingsService.java:285) at com.android.modules.utils.BasicShellCommandHandler.exec(BasicShellCommandHandler.java:97) at android.os.ShellCommand.exec(ShellCommand.java:38) at com.android.providers.settings.SettingsService.onShellCommand(SettingsService.java:53) at
03-20
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值