[求助]Android Manifest.xml文件中添加权限无效

Baggio_Wang 2015-09-10 10:39:34
各位大牛好!我刚学习Android,遇到了一个问题,看了几天无法解决,求助各位帮忙看下:

一个使用内容提供器读取通讯录的小例子,就是一个ListView读取contact中的联系人并显示。可是我运行后界面为空,log显示:

09-10 02:18:01.207: W/System.err(1091): java.lang.SecurityException: Permission Denial: opening provider com.android.providers.contacts.ContactsProvider2 from ProcessRecord{dd1f99c 1091:com.example.contactstest/u0a65} (pid=1091, uid=10065) requires android.permission.READ_CONTACTS or android.permission.WRITE_CONTACTS
09-10 02:18:01.208: W/System.err(1091): at android.os.Parcel.readException(Parcel.java:1599)
09-10 02:18:01.209: W/System.err(1091): at android.os.Parcel.readException(Parcel.java:1552)
09-10 02:18:01.209: W/System.err(1091): at android.app.ActivityManagerProxy.getContentProvider(ActivityManagerNative.java:3550)
09-10 02:18:01.209: W/System.err(1091): at android.app.ActivityThread.acquireProvider(ActivityThread.java:4778)
09-10 02:18:01.209: W/System.err(1091): at android.app.ContextImpl$ApplicationContentResolver.acquireUnstableProvider(ContextImpl.java:2018)
09-10 02:18:01.209: W/System.err(1091): at android.content.ContentResolver.acquireUnstableProvider(ContentResolver.java:1468)
09-10 02:18:01.209: W/System.err(1091): at android.content.ContentResolver.query(ContentResolver.java:475)
09-10 02:18:01.209: W/System.err(1091): at android.content.ContentResolver.query(ContentResolver.java:434)
09-10 02:18:01.210: W/System.err(1091): at com.example.contactstest.MainActivity.readContacts(MainActivity.java:39)
09-10 02:18:01.210: W/System.err(1091): at com.example.contactstest.MainActivity.onCreate(MainActivity.java:31)
09-10 02:18:01.210: W/System.err(1091): at android.app.Activity.performCreate(Activity.java:6237)
09-10 02:18:01.210: W/System.err(1091): at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1107)
09-10 02:18:01.210: W/System.err(1091): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2369)
09-10 02:18:01.210: W/System.err(1091): at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2476)
09-10 02:18:01.210: W/System.err(1091): at android.app.ActivityThread.-wrap11(ActivityThread.java)
09-10 02:18:01.210: W/System.err(1091): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1344)
09-10 02:18:01.211: W/System.err(1091): at android.os.Handler.dispatchMessage(Handler.java:102)
09-10 02:18:01.211: W/System.err(1091): at android.os.Looper.loop(Looper.java:148)
09-10 02:18:01.211: W/System.err(1091): at android.app.ActivityThread.main(ActivityThread.java:5417)
09-10 02:18:01.211: W/System.err(1091): at java.lang.reflect.Method.invoke(Native Method)
09-10 02:18:01.211: W/System.err(1091): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:726)
09-10 02:18:01.211: W/System.err(1091): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:616)

很明显是没有权限,我在AndroidManifest.xml中添加权限:
<uses-permission android:name="android.permission.READ_CONTACTS" />

运行还是出错,几天了都没解决,LOG和上面没加权限一样。eclipse我重新开了,重新运行模拟器还是一样。我的Android SDK是最新的6.0,是不是跟这个有关??求助各位了!!

PS:我之前的一个小例子,就是在广播中弹出TYPE_SYSTEM_ALERT类型的对话框去强制下线,添加了<uses-permission android:name="android.permission.SYSTEM_ALERT_WINDOW" /> 权限,也是报权限没申请。。。悲剧了。。。

AndroidManifest.xml:

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="com.example.contactstest"
android:versionCode="1"
android:versionName="1.0" >
<uses-permission android:name="android.permission.READ_CONTACTS" />

<uses-sdk
android:minSdkVersion="23"
android:targetSdkVersion="23" />

<application
android:allowBackup="true"
android:icon="@drawable/ic_launcher"
android:label="@string/app_name"
android:theme="@style/AppTheme" >
<activity
android:name=".MainActivity"
android:label="@string/app_name" >
<intent-filter>
<action android:name="android.intent.action.MAIN" />

<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity>
</application>

</manifest>
...全文
3555 7 打赏 收藏 转发到动态 举报
写回复
用AI写文章
7 条回复
切换为时间正序
请发表友善的回复…
发表回复
tilltheend_even 2017-11-10
  • 打赏
  • 举报
回复
Android6.0后还需要动态申请系统权限。在要用到相关权限前,附上 if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.M) { if( getApplicationContext().checkSelfPermission( Manifest.permission.READ_CONTACTS ) != PackageManager.PERMISSION_GRANTED ) ActivityCompat.requestPermissions(ContentProviderActivity.this, new String[]{Manifest.permission.READ_CONTACTS}, 1); }
闪耀的瞬间 2016-12-08
  • 打赏
  • 举报
回复
android6.0中,获取通讯录的权限是 <uses-permission android:name="android.permission.GET_ACCOUNTS"></uses-permission> 6.0之前的版本中的权限设置是 <uses-permission android:name="android.permission.READ_CONTACTS"></uses-permission>
qq_23311419 2015-11-23
  • 打赏
  • 举报
回复
我最近也碰到类似的问题,我的是写一个接收短信的app,代码没问题,权限代码添加,然后运行就是显示框内没有显示接收到信息,同样把代码复制一遍,再建立一个project,粘贴,然后运行又可以!
Baggio_Wang 2015-09-10
  • 打赏
  • 举报
回复
引用 1 楼 lxfhjjsfq 的回复:
android.permission.READ_CONTACTS or android.permission.WRITE_CONTACTS 你把write权限也加上再试试
还是不行,两个权限都加上了: <?xml version="1.0" encoding="utf-8"?> <manifest xmlns:android="http://schemas.android.com/apk/res/android" package="com.example.contactstest" android:versionCode="1" android:versionName="1.0" > <uses-permission android:name="android.permission.READ_CONTACTS" /> <uses-permission android:name="android.permission.WRITE_CONTACTS" /> <uses-sdk android:minSdkVersion="23" android:targetSdkVersion="23" /> ...... 还是报权限错误: 09-10 03:11:19.232: W/ActivityManager(314): Permission Denial: opening provider com.android.providers.contacts.ContactsProvider2 from ProcessRecord{86eff46 1617:com.example.contactstest/u0a65} (pid=1617, uid=10065) requires android.permission.READ_CONTACTS or android.permission.WRITE_CONTACTS 09-10 03:11:19.241: W/System.err(1617): java.lang.SecurityException: Permission Denial: opening provider com.android.providers.contacts.ContactsProvider2 from ProcessRecord{86eff46 1617:com.example.contactstest/u0a65} (pid=1617, uid=10065) requires android.permission.READ_CONTACTS or android.permission.WRITE_CONTACTS
_xianfeng99 2015-09-10
  • 打赏
  • 举报
回复
android.permission.READ_CONTACTS or android.permission.WRITE_CONTACTS 你把write权限也加上再试试
Baggio_Wang 2015-09-10
  • 打赏
  • 举报
回复
@hacker_crazy 感谢!果然是这个原因,换成SDK 22就好了。估计是6.0权限这块改动较大,还有待研究。结贴送分了哈!
hacker_crazy 2015-09-10
  • 打赏
  • 举报
回复
你用的sdk是23,这个版本权限获取已经改了,你去官网看看就知道了。改成22及以下就好了

80,352

社区成员

发帖
与我相关
我的任务
社区描述
移动平台 Android
androidandroid-studioandroidx 技术论坛(原bbs)
社区管理员
  • Android
  • yechaoa
  • 失落夏天
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧