【发布时间】:2017-07-01 11:23:55
【问题描述】:
我正在使用以下联系人获取应用程序的代码,我得到 Android 运行时:致命异常:第 17 行的主要错误。
package com.example.alpesh_pc.contactlist;
import android.app.Activity;
import android.database.Cursor;
import android.os.Bundle;
import android.provider.ContactsContract;
import android.widget.Toast;
public class MainActivity extends Activity
{
public Cursor cursor;
@Override
protected void onCreate(Bundle savedInstanceState)
{
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
cursor=this.getContentResolver().query(ContactsContract.Contacts.CONTENT_URI, null, null, null, null);
if(cursor.getCount()>0)
{
Toast.makeText(this, "Seccess", Toast.LENGTH_LONG).show();
}
}
}
下面是我的日志
E/AndroidRuntime: 致命异常: main 进程:com.example.alpesh_pc.contactlist,PID:3833 java.lang.RuntimeException:无法启动活动 ComponentInfo{com.example.alpesh_pc.contactlist/com.example.alpesh_pc.contactlist.MainActivity}:java.lang.SecurityException:权限被拒绝:打开提供程序 com.android.providers.contacts。 ProcessRecord{6970ad0 3833:com.example.alpesh_pc.contactlist/u0a67} (pid=3833, uid=10067) 中的 ContactsProvider2 需要 android.permission.READ_CONTACTS 或 android.permission.WRITE_CONTACTS 在 android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2646) 在 android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2707) 在 android.app.ActivityThread.-wrap12(ActivityThread.java) 在 android.app.ActivityThread$H.handleMessage(ActivityThread.java:1460) 在 android.os.Handler.dispatchMessage(Handler.java:102) 在 android.os.Looper.loop(Looper.java:154) 在 android.app.ActivityThread.main(ActivityThread.java:6077) 在 java.lang.reflect.Method.invoke(本机方法) 在 com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:865) 在 com.android.internal.os.ZygoteInit.main(ZygoteInit.java:755) 原因:java.lang.SecurityException: Permission Denial: 从 ProcessRecord{6970ad0 3833:com.example.alpesh_pc.contactlist/u0a67} (pid=3833, uid=10067) 打开提供程序 com.android.providers.contacts.ContactsProvider2 需要 android .permission.READ_CONTACTS 或 android.permission.WRITE_CONTACTS 在 android.os.Parcel.readException(Parcel.java:1683) 在 android.os.Parcel.readException(Parcel.java:1636) 在 android.app.ActivityManagerProxy.getContentProvider(ActivityManagerNative.java:4169) 在 android.app.ActivityThread.acquireProvider(ActivityThread.java:5434) 在 android.app.ContextImpl$ApplicationContentResolver.acquireUnstableProvider(ContextImpl.java:2267) 在 android.content.ContentResolver.acquireUnstableProvider(ContentResolver.java:1515) 在 android.content.ContentResolver.query(ContentResolver.java:514) 在 android.content.ContentResolver.query(ContentResolver.java:472) 在 com.example.alpesh_pc.contactlist.MainActivity.onCreate(MainActivity.java:17) 在 android.app.Activity.performCreate(Activity.java:6662) 在 android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1118) 在 android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2599) 在 android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2707) 在 android.app.ActivityThread.-wrap12(ActivityThread.java) 在 android.app.ActivityThread$H.handleMessage(ActivityThread.java:1460) 在 android.os.Handler.dispatchMessage(Handler.java:102) 在 android.os.Looper.loop(Looper.java:154) 在 android.app.ActivityThread.main(ActivityThread.java:6077) 在 java.lang.reflect.Method.invoke(本机方法) 在 com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:865) 在 com.android.internal.os.ZygoteInit.main(ZygoteInit.java:755) 应用程序终止。
【问题讨论】:
-
请分享你的logcat
-
请再次检查问题,我已使用 logcat 对其进行了修改。谢谢。 @TahmidRahman
-
请检查我的回答