在一个应用程序中,我在AndroidManifest中声明了以下内容提供程序:
<provider android:name="com.example.MyProvider"
android:label="@string/provider_name"
android:authorities="com.example"
android:readPermission="com.example.permission.READ"
/>
另一个应用程序请求使用它的权限:
<uses-permission android:name="com.example.permission.READ" />
但是在运行此代码时:
ContentResolver resolver = this.context.getContentResolver();
Cursor results = resolver.query(BaseballCardContract.CONTENT_URI, BaseballCardContract.PROJECTION, null, null, null);
我收到以下错误消息:
E / DatabaseUtils(1009):java.lang.SecurityException:Permission Denial:读取bbct.android.common.BaseballCardProvider uri content://bbct.android.baseballcard/baseball_cards from pid = 996,uid = 10046需要com。 example.permission.READ或grantUriPermission()
据我所知,我正在申请所需的许可。我在这里错过了什么?我还需要注意什么?
答案 0 :(得分:9)
在定义ContentProvider的应用中,您是否还定义了您需要/请求的权限(在您的其他应用中)?像这样(在根<manifest/>
标签内):
<permission android:name="com.example.permission.READ" />
一般来说,你需要:
编辑:所以只是要100%明确,仅仅通过在ContentProvider中要求它来“隐式”定义权限是不够的。您必须在应用的清单文件中明确定义它(在<manifest/>
标记内)。