2014-11-02 93 views
0

我正在尝试通过Intent访问我的联系人列表以获取号码,但我正在创建一个例外。从您的联系人列表中获取号码

java.lang.IllegalStateException:无法从CursorWindow读取行0,col -1。在从中访问数据之前,确保Cursor已正确初始化。

这是我的代码:

// In some function 
     Intent intent = new Intent(Intent.ACTION_PICK, ContactsContract.Contacts.CONTENT_URI); 
     startActivityForResult(intent, Constants.PICK_CONTACT); 
    } 

    public void onActivityResult (int requestCode, int resultCode, Intent data) { 
    Cursor cursor = null; 
    if (resultCode == RESULT_OK && requestCode == Constants.PICK_CONTACT){ 
     try { 

      Uri contactData = data.getData(); 
      Cursor c = getContentResolver().query(contactData, null, null, null, null); 
      if (c.moveToFirst()) { 
       String number = c.getString(c.getColumnIndex(ContactsContract.PhoneLookup.NUMBER)); 
       // do some stuff 
      } 
     } catch (Exception e) { 
      StringWriter errors = new StringWriter(); 
      e.printStackTrace(new PrintWriter(errors)); 
      Log.i("Excepetion", errors.toString()); 
     } finally { 
      if (cursor != null) { 
       cursor.close(); 
      } 
     } 
    } 
} 

堆栈跟踪为这一个:

11-02 03:17:36.469: I/Excepetion(25527): java.lang.IllegalStateException: Couldn't read row 0, col -1 from CursorWindow. Make sure the Cursor is initialized correctly before accessing data from it. 
11-02 03:17:36.469: I/Excepetion(25527): at android.database.CursorWindow.nativeGetString(Native Method) 
11-02 03:17:36.469: I/Excepetion(25527): at android.database.CursorWindow.getString(CursorWindow.java:434) 
11-02 03:17:36.469: I/Excepetion(25527): at android.database.AbstractWindowedCursor.getString(AbstractWindowedCursor.java:51) 
11-02 03:17:36.469: I/Excepetion(25527): at android.database.CursorWrapper.getString(CursorWrapper.java:114) 
11-02 03:17:36.469: I/Excepetion(25527): at com.example.example.SendPrivateInfoActivity.onActivityResult(SendPrivateInfoActivity.java:76) 
11-02 03:17:36.469: I/Excepetion(25527): at android.app.Activity.dispatchActivityResult(Activity.java:5322) 
11-02 03:17:36.469: I/Excepetion(25527): at android.app.ActivityThread.deliverResults(ActivityThread.java:3363) 
11-02 03:17:36.469: I/Excepetion(25527): at android.app.ActivityThread.handleSendResult(ActivityThread.java:3410) 
11-02 03:17:36.469: I/Excepetion(25527): at android.app.ActivityThread.access$1100(ActivityThread.java:141) 
11-02 03:17:36.469: I/Excepetion(25527): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1304) 
11-02 03:17:36.469: I/Excepetion(25527): at android.os.Handler.dispatchMessage(Handler.java:99) 
11-02 03:17:36.469: I/Excepetion(25527): at android.os.Looper.loop(Looper.java:137) 
11-02 03:17:36.469: I/Excepetion(25527): at android.app.ActivityThread.main(ActivityThread.java:5103) 
11-02 03:17:36.469: I/Excepetion(25527): at java.lang.reflect.Method.invokeNative(Native Method) 
11-02 03:17:36.469: I/Excepetion(25527): at java.lang.reflect.Method.invoke(Method.java:525) 
11-02 03:17:36.469: I/Excepetion(25527): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:737) 
11-02 03:17:36.469: I/Excepetion(25527): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:553) 
11-02 03:17:36.469: I/Excepetion(25527): at dalvik.system.NativeStart.main(Native Method) 

回答

0

首先,确保你选择一个联系人的联系number.This可以通过将完成android.provider.ContactsContract.Contacts.HAS_PHONE_NUMBER有关resolver.query()的第三个参数。

其次尝试ContactsContract.CommonDataKinds.Phone.NUMBER代替ContactsContract.PhoneLookup.NUMBER

+0

,它仍然抛出与变化异常,你指出:( – Fernando 2014-11-02 11:52:17

相关问题