Androidは連絡先情報(名前、電話番号、住所、メールボックス、誕生日など)を読み取る


最近、携帯電話の連絡先の名前、携帯電話番号、住所、会社、メールボックスなどの情報を引き出してみました.
public void testGetAllContact() throws Throwable  
{  
    //        Uri  
    Uri uri = ContactsContract.Contacts.CONTENT_URI;  
    //  ContentResolver  
    ContentResolver contentResolver = ContactListActivity.this.getContentResolver();  
    //    ,  Cursor  
    Cursor cursor = contentResolver.query(uri, null, null, null, null);  
    List> list = new ArrayList>();  
    while(cursor.moveToNext())  
    {  
        Map map = new HashMap();  
        StringBuilder sb = new StringBuilder();  
        //      ID  
        String contactId = cursor.getString(cursor.getColumnIndex(ContactsContract.Contacts._ID));  
        //          
        String name = cursor.getString(cursor.getColumnIndex(ContactsContract.Contacts.DISPLAY_NAME));  
        //         
        sb.append("contactId=").append(contactId).append(",Name=").append(name);  
        map.put("name", name);  
        String id = cursor.getString(cursor.getColumnIndex(ContactsContract.Contacts._ID));//   ID   
  
  
        //             
        Cursor phones = contentResolver.query(ContactsContract.CommonDataKinds.Phone.CONTENT_URI,  
                null,  
                ContactsContract.CommonDataKinds.Phone.CONTACT_ID +" = "+ contactId,  
                null, null);  
        while(phones.moveToNext())  
        {  
            String phoneNumber = phones.getString(phones.getColumnIndex(  
                    ContactsContract.CommonDataKinds.Phone.NUMBER));  
            //  Phone     
            sb.append(",Phone=").append(phoneNumber);  
            map.put("mobile", phoneNumber);  
        }  
        phones.close();  
  
  
        //  Email         
        Cursor emails = contentResolver.query(ContactsContract.CommonDataKinds.Email.CONTENT_URI,  
                null,  
                ContactsContract.CommonDataKinds.Email.CONTACT_ID + " = " + contactId,  
                null, null);  
        while (emails.moveToNext())  
        {  
            String emailAddress = emails.getString(emails.getColumnIndex(  
                    ContactsContract.CommonDataKinds.Email.DATA));  
            //  Email     
            sb.append(",Email=").append(emailAddress);  
            Log.e("emailAddress", emailAddress);  
            map.put("email", emailAddress);  
  
  
        }  
        emails.close();  
        //Log.i("=========ddddddddddd=====", sb.toString());  
  
        //  ==  ==       .StructuredPostal.TYPE_WORK  
        Cursor address = contentResolver.query(ContactsContract.CommonDataKinds.StructuredPostal.CONTENT_URI,  
                null,  
                ContactsContract.CommonDataKinds.StructuredPostal.CONTACT_ID + " = " + contactId,  
                null, null);  
        while (address.moveToNext())  
        {  
            String workAddress = address.getString(address.getColumnIndex(  
                    ContactsContract.CommonDataKinds.StructuredPostal.DATA));  
  
  
            //  Email     
            sb.append(",address").append(workAddress);  
            map.put("address", workAddress);  
        }  
        address.close();  
        //Log.i("=========ddddddddddd=====", sb.toString());  
  
        //  ==    ==       .Organization.COMPANY  ContactsContract.Data.CONTENT_URI  
        String orgWhere = ContactsContract.Data.CONTACT_ID + " = ? AND " + ContactsContract.Data.MIMETYPE + " = ?";   
        String[] orgWhereParams = new String[]{id,   
                ContactsContract.CommonDataKinds.Organization.CONTENT_ITEM_TYPE};   
        Cursor orgCur = contentResolver.query(ContactsContract.Data.CONTENT_URI,   
                null, orgWhere, orgWhereParams, null);   
        if (orgCur.moveToFirst()) {   
            //    (    )  
            String company = orgCur.getString(orgCur.getColumnIndex(ContactsContract.CommonDataKinds.Organization.DATA));   
            //     
            String title = orgCur.getString(orgCur.getColumnIndex(ContactsContract.CommonDataKinds.Organization.TITLE));   
            sb.append(",company").append(company);  
            sb.append(",title").append(title);  
            map.put("company", company);  
            map.put("title", title);  
        }   
        orgCur.close();   
        list.add(map);  
        Log.i("=========orgName=====", sb.toString());//         
        Log.e("=========map=====", map.toString());//        ,            ,  
    }  
  
    Log.i("=========list=====", list.toString());//  
    cursor.close();      
} 

アクセス権を追加してください:
  
      
      
      
      
      
      
      

具体的な列を見てみましょう.
import java.util.ArrayList;  
import java.util.List;  
  
import org.json.JSONException;  
import org.json.JSONObject;  
  
import android.content.ContentResolver;  
import android.content.Context;  
import android.database.Cursor;  
import android.net.Uri;  
import android.provider.ContactsContract;  
import android.provider.CallLog.Calls;  
import android.provider.ContactsContract.CommonDataKinds.Email;  
import android.provider.ContactsContract.CommonDataKinds.Event;  
import android.provider.ContactsContract.CommonDataKinds.Im;  
import android.provider.ContactsContract.CommonDataKinds.Nickname;  
import android.provider.ContactsContract.CommonDataKinds.Note;  
import android.provider.ContactsContract.CommonDataKinds.Organization;  
import android.provider.ContactsContract.CommonDataKinds.Phone;  
import android.provider.ContactsContract.CommonDataKinds.StructuredName;  
import android.provider.ContactsContract.CommonDataKinds.StructuredPostal;  
import android.provider.ContactsContract.CommonDataKinds.Website;  
import android.provider.ContactsContract.Contacts;  
import android.provider.ContactsContract.Data;  
import android.util.Log;  
  
/**  
 *   
 * @author larson  
 *  
 */    
public class ContactUtil {    
    public  List list;    
    private Context context;    
    private  JSONObject contactData;    
    private  JSONObject jsonObject;    
  
    public ContactUtil(Context context) {    
        this.context = context;    
    }    
  
    // ContactsContract.Contacts.CONTENT_URI= content://com.android.contacts/contacts;    
    // ContactsContract.Data.CONTENT_URI = content://com.android.contacts/data;    
  
    /**  
     *        ,       json    
     *   
     * @return  
     * @throws JSONException  
     */    
    public String getContactInfo() throws JSONException {    
        list = new ArrayList();    
        contactData = new JSONObject();    
        String mimetype = "";    
        int oldrid = -1;    
        int contactId = -1;    
        // 1.            ,  id  ,    android        ,           RAW_CONTACT_ID         
        //   ,        RAW_CONTACT_ID    
        Uri uri = ContactsContract.Data.CONTENT_URI; //    Uri;    
        Cursor cursor = context.getContentResolver().query(uri,    
                null, null, null, Data.RAW_CONTACT_ID);    
        int numm = 0;    
        while (cursor.moveToNext()) {    
            contactId = cursor.getInt(cursor    
                    .getColumnIndex(Data.RAW_CONTACT_ID));    
            if (oldrid != contactId) {    
                jsonObject = new JSONObject();    
                contactData.put("contact" + numm, jsonObject);    
                numm++;    
                oldrid = contactId;    
            }    
            mimetype = cursor.getString(cursor.getColumnIndex(Data.MIMETYPE)); //   mimetype  ,                 
            // 1.1,              
            if (StructuredName.CONTENT_ITEM_TYPE.equals(mimetype)) {    
                cursor.getString(cursor    
                        .getColumnIndex(StructuredName.DISPLAY_NAME));    
                String prefix = cursor.getString(cursor    
                        .getColumnIndex(StructuredName.PREFIX));    
                jsonObject.put("prefix", prefix);    
                String firstName = cursor.getString(cursor    
                        .getColumnIndex(StructuredName.FAMILY_NAME));    
                jsonObject.put("firstName", firstName);    
                String middleName = cursor.getString(cursor    
                        .getColumnIndex(StructuredName.MIDDLE_NAME));    
                jsonObject.put("middleName", middleName);    
                String lastname = cursor.getString(cursor    
                        .getColumnIndex(StructuredName.GIVEN_NAME));    
                jsonObject.put("lastname", lastname);    
                String suffix = cursor.getString(cursor    
                        .getColumnIndex(StructuredName.SUFFIX));    
                jsonObject.put("suffix", suffix);    
                String phoneticFirstName = cursor.getString(cursor    
                        .getColumnIndex(StructuredName.PHONETIC_FAMILY_NAME));    
                jsonObject.put("phoneticFirstName", phoneticFirstName);    
  
                String phoneticMiddleName = cursor.getString(cursor    
                        .getColumnIndex(StructuredName.PHONETIC_MIDDLE_NAME));    
                jsonObject.put("phoneticMiddleName", phoneticMiddleName);    
                String phoneticLastName = cursor.getString(cursor    
                        .getColumnIndex(StructuredName.PHONETIC_GIVEN_NAME));    
                jsonObject.put("phoneticLastName", phoneticLastName);    
            }    
            // 1.2             
            if (Phone.CONTENT_ITEM_TYPE.equals(mimetype)) {    
                int phoneType = cursor    
                        .getInt(cursor.getColumnIndex(Phone.TYPE)); //       
                if (phoneType == Phone.TYPE_MOBILE) {    
                    String mobile = cursor.getString(cursor    
                            .getColumnIndex(Phone.NUMBER));    
                    jsonObject.put("mobile", mobile);    
                }    
                //         
                if (phoneType == Phone.TYPE_HOME) {    
                    String homeNum = cursor.getString(cursor    
                            .getColumnIndex(Phone.NUMBER));    
                    jsonObject.put("homeNum", homeNum);    
                }    
                //         
                if (phoneType == Phone.TYPE_WORK) {    
                    String jobNum = cursor.getString(cursor    
                            .getColumnIndex(Phone.NUMBER));    
                    jsonObject.put("jobNum", jobNum);    
                }    
                //         
                if (phoneType == Phone.TYPE_FAX_WORK) {    
                    String workFax = cursor.getString(cursor    
                            .getColumnIndex(Phone.NUMBER));    
                    jsonObject.put("workFax", workFax);    
                }    
                //         
                if (phoneType == Phone.TYPE_FAX_HOME) {    
                    String homeFax = cursor.getString(cursor    
                            .getColumnIndex(Phone.NUMBER));    
  
                    jsonObject.put("homeFax", homeFax);    
                } //        
                if (phoneType == Phone.TYPE_PAGER) {    
                    String pager = cursor.getString(cursor    
                            .getColumnIndex(Phone.NUMBER));    
                    jsonObject.put("pager", pager);    
                }    
                //         
                if (phoneType == Phone.TYPE_CALLBACK) {    
                    String quickNum = cursor.getString(cursor    
                            .getColumnIndex(Phone.NUMBER));    
                    jsonObject.put("quickNum", quickNum);    
                }    
                //         
                if (phoneType == Phone.TYPE_COMPANY_MAIN) {    
                    String jobTel = cursor.getString(cursor    
                            .getColumnIndex(Phone.NUMBER));    
                    jsonObject.put("jobTel", jobTel);    
                }    
                //         
                if (phoneType == Phone.TYPE_CAR) {    
                    String carNum = cursor.getString(cursor    
                            .getColumnIndex(Phone.NUMBER));    
                    jsonObject.put("carNum", carNum);    
                } // ISDN    
                if (phoneType == Phone.TYPE_ISDN) {    
                    String isdn = cursor.getString(cursor    
                            .getColumnIndex(Phone.NUMBER));    
                    jsonObject.put("isdn", isdn);    
                } //       
                if (phoneType == Phone.TYPE_MAIN) {    
                    String tel = cursor.getString(cursor    
                            .getColumnIndex(Phone.NUMBER));    
                    jsonObject.put("tel", tel);    
                }    
                //         
                if (phoneType == Phone.TYPE_RADIO) {    
                    String wirelessDev = cursor.getString(cursor    
                            .getColumnIndex(Phone.NUMBER));    
  
                    jsonObject.put("wirelessDev", wirelessDev);    
                } //       
                if (phoneType == Phone.TYPE_TELEX) {    
                    String telegram = cursor.getString(cursor    
                            .getColumnIndex(Phone.NUMBER));    
                    jsonObject.put("telegram", telegram);    
                }    
                // TTY_TDD    
                if (phoneType == Phone.TYPE_TTY_TDD) {    
                    String tty_tdd = cursor.getString(cursor    
                            .getColumnIndex(Phone.NUMBER));    
                    jsonObject.put("tty_tdd", tty_tdd);    
                }    
                //         
                if (phoneType == Phone.TYPE_WORK_MOBILE) {    
                    String jobMobile = cursor.getString(cursor    
                            .getColumnIndex(Phone.NUMBER));    
                    jsonObject.put("jobMobile", jobMobile);    
                }    
                //          
                if (phoneType == Phone.TYPE_WORK_PAGER) {    
                    String jobPager = cursor.getString(cursor    
                            .getColumnIndex(Phone.NUMBER));    
                    jsonObject.put("jobPager", jobPager);    
                } //       
                if (phoneType == Phone.TYPE_ASSISTANT) {    
                    String assistantNum = cursor.getString(cursor    
                            .getColumnIndex(Phone.NUMBER));    
                    jsonObject.put("assistantNum", assistantNum);    
                } //       
                if (phoneType == Phone.TYPE_MMS) {    
                    String mms = cursor.getString(cursor    
                            .getColumnIndex(Phone.NUMBER));    
                    jsonObject.put("mms", mms);    
                }    
  
                String mobileEmail = cursor.getString(cursor    
                        .getColumnIndex(Email.DATA));    
                jsonObject.put("mobileEmail", mobileEmail);    
            }    
        }    
        //   event      
        if (Event.CONTENT_ITEM_TYPE.equals(mimetype)) { //           
            int eventType = cursor.getInt(cursor.getColumnIndex(Event.TYPE)); //       
            if (eventType == Event.TYPE_BIRTHDAY) {    
                String birthday = cursor.getString(cursor    
                        .getColumnIndex(Event.START_DATE));    
                jsonObject.put("birthday", birthday);    
            }    
            //          
            if (eventType == Event.TYPE_ANNIVERSARY) {    
                String anniversary = cursor.getString(cursor    
                        .getColumnIndex(Event.START_DATE));    
                jsonObject.put("anniversary", anniversary);    
            }    
        }    
        //             
        if (Im.CONTENT_ITEM_TYPE.equals(mimetype)) { //             
            int protocal = cursor.getInt(cursor.getColumnIndex(Im.PROTOCOL));    
            if (Im.TYPE_CUSTOM == protocal) {    
                String workMsg = cursor.getString(cursor    
                        .getColumnIndex(Im.DATA));    
                jsonObject.put("workMsg", workMsg);    
            } else if (Im.PROTOCOL_MSN == protocal) {    
                String workMsg = cursor.getString(cursor    
                        .getColumnIndex(Im.DATA));    
                jsonObject.put("workMsg", workMsg);    
            }    
            if (Im.PROTOCOL_QQ == protocal) {    
                String instantsMsg = cursor.getString(cursor    
                        .getColumnIndex(Im.DATA));    
  
                jsonObject.put("instantsMsg", instantsMsg);    
            }    
        }    
        //           
        if (Note.CONTENT_ITEM_TYPE.equals(mimetype)) {    
            String remark = cursor.getString(cursor.getColumnIndex(Note.NOTE));    
            jsonObject.put("remark", remark);    
        }    
        //           
        if (Nickname.CONTENT_ITEM_TYPE.equals(mimetype)) {    
            String nickName = cursor.getString(cursor    
                    .getColumnIndex(Nickname.NAME));    
            jsonObject.put("nickName", nickName);    
        }    
        //           
        if (Organization.CONTENT_ITEM_TYPE.equals(mimetype)) { //           
            int orgType = cursor.getInt(cursor    
                    .getColumnIndex(Organization.TYPE)); //       
            if (orgType == Organization.TYPE_CUSTOM) { // if (orgType ==    
                // Organization.TYPE_WORK)    
                // {    
                String company = cursor.getString(cursor    
                        .getColumnIndex(Organization.COMPANY));    
                jsonObject.put("company", company);    
                String jobTitle = cursor.getString(cursor    
                        .getColumnIndex(Organization.TITLE));    
                jsonObject.put("jobTitle", jobTitle);    
                String department = cursor.getString(cursor    
                        .getColumnIndex(Organization.DEPARTMENT));    
                jsonObject.put("department", department);    
            }    
        }    
        //           
        if (Website.CONTENT_ITEM_TYPE.equals(mimetype)) { //           
            int webType = cursor.getInt(cursor.getColumnIndex(Website.TYPE)); //       
            if (webType == Website.TYPE_CUSTOM) {    
  
                String home = cursor.getString(cursor    
                        .getColumnIndex(Website.URL));    
                jsonObject.put("home", home);    
            } //       
            else if (webType == Website.TYPE_HOME) {    
                String home = cursor.getString(cursor    
                        .getColumnIndex(Website.URL));    
                jsonObject.put("home", home);    
            }    
            //         
            if (webType == Website.TYPE_HOMEPAGE) {    
                String homePage = cursor.getString(cursor    
                        .getColumnIndex(Website.URL));    
                jsonObject.put("homePage", homePage);    
            }    
            //         
            if (webType == Website.TYPE_WORK) {    
                String workPage = cursor.getString(cursor    
                        .getColumnIndex(Website.URL));    
                jsonObject.put("workPage", workPage);    
            }    
        }    
        //           
        if (StructuredPostal.CONTENT_ITEM_TYPE.equals(mimetype)) { //           
            int postalType = cursor.getInt(cursor    
                    .getColumnIndex(StructuredPostal.TYPE)); //           
            if (postalType == StructuredPostal.TYPE_WORK) {    
                String street = cursor.getString(cursor    
                        .getColumnIndex(StructuredPostal.STREET));    
                jsonObject.put("street", street);    
                String ciry = cursor.getString(cursor    
                        .getColumnIndex(StructuredPostal.CITY));    
                jsonObject.put("ciry", ciry);    
                String box = cursor.getString(cursor    
                        .getColumnIndex(StructuredPostal.POBOX));    
                jsonObject.put("box", box);    
                String area = cursor.getString(cursor    
                        .getColumnIndex(StructuredPostal.NEIGHBORHOOD));    
                jsonObject.put("area", area);    
  
                String state = cursor.getString(cursor    
                        .getColumnIndex(StructuredPostal.REGION));    
                jsonObject.put("state", state);    
                String zip = cursor.getString(cursor    
                        .getColumnIndex(StructuredPostal.POSTCODE));    
                jsonObject.put("zip", zip);    
                String country = cursor.getString(cursor    
                        .getColumnIndex(StructuredPostal.COUNTRY));    
                jsonObject.put("country", country);    
            }    
            //           
            if (postalType == StructuredPostal.TYPE_HOME) {    
                String homeStreet = cursor.getString(cursor    
                        .getColumnIndex(StructuredPostal.STREET));    
                jsonObject.put("homeStreet", homeStreet);    
                String homeCity = cursor.getString(cursor    
                        .getColumnIndex(StructuredPostal.CITY));    
                jsonObject.put("homeCity", homeCity);    
                String homeBox = cursor.getString(cursor    
                        .getColumnIndex(StructuredPostal.POBOX));    
                jsonObject.put("homeBox", homeBox);    
                String homeArea = cursor.getString(cursor    
                        .getColumnIndex(StructuredPostal.NEIGHBORHOOD));    
                jsonObject.put("homeArea", homeArea);    
                String homeState = cursor.getString(cursor    
                        .getColumnIndex(StructuredPostal.REGION));    
                jsonObject.put("homeState", homeState);    
                String homeZip = cursor.getString(cursor    
                        .getColumnIndex(StructuredPostal.POSTCODE));    
                jsonObject.put("homeZip", homeZip);    
                String homeCountry = cursor.getString(cursor    
                        .getColumnIndex(StructuredPostal.COUNTRY));    
                jsonObject.put("homeCountry", homeCountry);    
            }    
            //           
            if (postalType == StructuredPostal.TYPE_OTHER) {    
                String otherStreet = cursor.getString(cursor    
                        .getColumnIndex(StructuredPostal.STREET));    
                jsonObject.put("otherStreet", otherStreet);    
  
                String otherCity = cursor.getString(cursor    
                        .getColumnIndex(StructuredPostal.CITY));    
                jsonObject.put("otherCity", otherCity);    
                String otherBox = cursor.getString(cursor    
                        .getColumnIndex(StructuredPostal.POBOX));    
                jsonObject.put("otherBox", otherBox);    
                String otherArea = cursor.getString(cursor    
                        .getColumnIndex(StructuredPostal.NEIGHBORHOOD));    
                jsonObject.put("otherArea", otherArea);    
                String otherState = cursor.getString(cursor    
                        .getColumnIndex(StructuredPostal.REGION));    
                jsonObject.put("otherState", otherState);    
                String otherZip = cursor.getString(cursor    
                        .getColumnIndex(StructuredPostal.POSTCODE));    
                jsonObject.put("otherZip", otherZip);    
                String otherCountry = cursor.getString(cursor    
                        .getColumnIndex(StructuredPostal.COUNTRY));    
                jsonObject.put("otherCountry", otherCountry);    
            }    
        }    
        cursor.close();    
        Log.i("contactData", contactData.toString());    
        return contactData.toString();    
    }  
  
  
} 

直接実行:
import org.json.JSONException;  
import org.json.JSONObject;  
  
import android.app.Activity;  
import android.database.Cursor;  
import android.os.Bundle;  
import android.provider.ContactsContract.CommonDataKinds.Email;  
import android.provider.ContactsContract.CommonDataKinds.Event;  
import android.provider.ContactsContract.CommonDataKinds.Im;  
import android.provider.ContactsContract.CommonDataKinds.Nickname;  
import android.provider.ContactsContract.CommonDataKinds.Note;  
import android.provider.ContactsContract.CommonDataKinds.Organization;  
import android.provider.ContactsContract.CommonDataKinds.Phone;  
import android.provider.ContactsContract.CommonDataKinds.StructuredName;  
import android.provider.ContactsContract.CommonDataKinds.StructuredPostal;  
import android.provider.ContactsContract.CommonDataKinds.Website;  
import android.provider.ContactsContract.Data;  
import android.util.Log;  
  
  
public class MainActivity extends Activity {  
  
    private static final String TAG = "MainActivity";  
  
    private JSONObject contactData;  
    private JSONObject jsonObject;  
    protected void onCreate(Bundle savedInstanceState) {  
        super.onCreate(savedInstanceState);  
        setContentView(R.layout.activity_main);  
        try {  
            getContactInfo();  
        } catch (JSONException e) {  
            // TODO Auto-generated catch block  
            e.printStackTrace();  
        }  
  
    }  
    public String getContactInfo() throws JSONException {  
        //         ,URI ContactsContract.Contacts.CONTENT_URI  
  
        contactData = new JSONObject();  
        String mimetype = "";  
        int oldrid = -1;  
        int contactId = -1;  
        Cursor cursor = getContentResolver().query(Data.CONTENT_URI,null, null, null, Data.RAW_CONTACT_ID);  
        int numm=0;  
        while (cursor.moveToNext()) {  
            contactId = cursor.getInt(cursor.getColumnIndex(Data.RAW_CONTACT_ID));   
            if (oldrid != contactId) {  
                jsonObject = new JSONObject();  
                contactData.put("contact" + numm, jsonObject);  
                numm++;  
                oldrid = contactId;  
            }  
  
            //   mimetype    
            mimetype = cursor.getString(cursor.getColumnIndex(Data.MIMETYPE));  
            //             ID  
            //               
            if (StructuredName.CONTENT_ITEM_TYPE.equals(mimetype)) {  
                //          String display_name = cursor.getString(cursor.getColumnIndex(StructuredName.DISPLAY_NAME));  
                String prefix = cursor.getString(cursor.getColumnIndex(StructuredName.PREFIX));  
                jsonObject.put("prefix", prefix);  
                String firstName = cursor.getString(cursor.getColumnIndex(StructuredName.FAMILY_NAME));  
                jsonObject.put("firstName", firstName);  
                String middleName = cursor.getString(cursor.getColumnIndex(StructuredName.MIDDLE_NAME));  
                jsonObject.put("middleName", middleName);  
                String lastname = cursor.getString(cursor.getColumnIndex(StructuredName.GIVEN_NAME));  
                jsonObject.put("lastname", lastname);  
                String suffix = cursor.getString(cursor.getColumnIndex(StructuredName.SUFFIX));  
                jsonObject.put("suffix", suffix);  
                String phoneticFirstName = cursor.getString(cursor.getColumnIndex(StructuredName.PHONETIC_FAMILY_NAME));  
                jsonObject.put("phoneticFirstName", phoneticFirstName);  
                String phoneticMiddleName = cursor.getString(cursor.getColumnIndex(StructuredName.PHONETIC_MIDDLE_NAME));  
                jsonObject.put("phoneticMiddleName", phoneticMiddleName);  
                String phoneticLastName = cursor.getString(cursor.getColumnIndex(StructuredName.PHONETIC_GIVEN_NAME));  
                jsonObject.put("phoneticLastName", phoneticLastName);  
            }  
            //         
            if (Phone.CONTENT_ITEM_TYPE.equals(mimetype)) {  
                //         
                int phoneType = cursor.getInt(cursor.getColumnIndex(Phone.TYPE));  
                //     
                if (phoneType == Phone.TYPE_MOBILE) {  
                    String mobile = cursor.getString(cursor.getColumnIndex(Phone.NUMBER));  
                    jsonObject.put("mobile", mobile);  
                }  
                //       
                if (phoneType == Phone.TYPE_HOME) {  
                    String homeNum = cursor.getString(cursor.getColumnIndex(Phone.NUMBER));  
                    jsonObject.put("homeNum", homeNum);  
                }  
                //       
                if (phoneType == Phone.TYPE_WORK) {  
                    String jobNum = cursor.getString(cursor.getColumnIndex(Phone.NUMBER));  
                    jsonObject.put("jobNum", jobNum);  
                }  
                //       
                if (phoneType == Phone.TYPE_FAX_WORK) {  
                    String workFax = cursor.getString(cursor.getColumnIndex(Phone.NUMBER));  
                    jsonObject.put("workFax", workFax);  
                }  
                //       
                if (phoneType == Phone.TYPE_FAX_HOME) {  
                    String homeFax = cursor.getString(cursor.getColumnIndex(Phone.NUMBER));  
                    jsonObject.put("homeFax", homeFax);  
                }  
                //      
                if (phoneType == Phone.TYPE_PAGER) {  
                    String pager = cursor.getString(cursor.getColumnIndex(Phone.NUMBER));  
                    jsonObject.put("pager", pager);  
                }  
                //       
                if (phoneType == Phone.TYPE_CALLBACK) {  
                    String quickNum = cursor.getString(cursor.getColumnIndex(Phone.NUMBER));  
                    jsonObject.put("quickNum", quickNum);  
                }  
                //       
                if (phoneType == Phone.TYPE_COMPANY_MAIN) {  
                    String jobTel = cursor.getString(cursor.getColumnIndex(Phone.NUMBER));  
                    jsonObject.put("jobTel", jobTel);  
                }  
                //       
                if (phoneType == Phone.TYPE_CAR) {  
                    String carNum = cursor.getString(cursor.getColumnIndex(Phone.NUMBER));  
                    jsonObject.put("carNum", carNum);  
                }  
                // ISDN  
                if (phoneType == Phone.TYPE_ISDN) {  
                    String isdn = cursor.getString(cursor.getColumnIndex(Phone.NUMBER));  
                    jsonObject.put("isdn", isdn);  
                }  
                //     
                if (phoneType == Phone.TYPE_MAIN) {  
                    String tel = cursor.getString(cursor.getColumnIndex(Phone.NUMBER));  
                    jsonObject.put("tel", tel);  
                }  
                //       
                if (phoneType == Phone.TYPE_RADIO) {  
                    String wirelessDev = cursor.getString(cursor.getColumnIndex(Phone.NUMBER));  
                    jsonObject.put("wirelessDev", wirelessDev);  
                }  
                //     
                if (phoneType == Phone.TYPE_TELEX) {  
                    String telegram = cursor.getString(cursor.getColumnIndex(Phone.NUMBER));  
                    jsonObject.put("telegram", telegram);  
                }  
                // TTY_TDD  
                if (phoneType == Phone.TYPE_TTY_TDD) {  
                    String tty_tdd = cursor.getString(cursor.getColumnIndex(Phone.NUMBER));  
                    jsonObject.put("tty_tdd", tty_tdd);  
                }  
                //       
                if (phoneType == Phone.TYPE_WORK_MOBILE) {  
                    String jobMobile = cursor.getString(cursor.getColumnIndex(Phone.NUMBER));  
                    jsonObject.put("jobMobile", jobMobile);  
                }  
                //        
                if (phoneType == Phone.TYPE_WORK_PAGER) {  
                    String jobPager = cursor.getString(cursor.getColumnIndex(Phone.NUMBER));  
                    jsonObject.put("jobPager", jobPager);  
                }  
                //     
                if (phoneType == Phone.TYPE_ASSISTANT) {  
                    String assistantNum = cursor.getString(cursor.getColumnIndex(Phone.NUMBER));  
                    jsonObject.put("assistantNum", assistantNum);  
                }  
                //     
                if (phoneType == Phone.TYPE_MMS) {  
                    String mms = cursor.getString(cursor.getColumnIndex(Phone.NUMBER));  
                    jsonObject.put("mms", mms);  
                }  
            }  
            // }  
            //   email    
            if (Email.CONTENT_ITEM_TYPE.equals(mimetype)) {  
                //         
                int emailType = cursor.getInt(cursor.getColumnIndex(Email.TYPE));  
  
                //         
                if (emailType == Email.TYPE_CUSTOM) {  
                    String homeEmail = cursor.getString(cursor.getColumnIndex(Email.DATA));  
                    jsonObject.put("homeEmail", homeEmail);  
                }  
  
                //         
                else if (emailType == Email.TYPE_HOME) {  
                    String homeEmail = cursor.getString(cursor.getColumnIndex(Email.DATA));  
                    jsonObject.put("homeEmail", homeEmail);  
                }  
                //         
                if (emailType == Email.TYPE_CUSTOM) {  
                    String jobEmail = cursor.getString(cursor.getColumnIndex(Email.DATA));  
                    jsonObject.put("jobEmail", jobEmail);  
                }  
  
                //         
                else if (emailType == Email.TYPE_WORK) {  
                    String jobEmail = cursor.getString(cursor.getColumnIndex(Email.DATA));  
                    jsonObject.put("jobEmail", jobEmail);  
                }  
                //         
                if (emailType == Email.TYPE_CUSTOM) {  
                    String mobileEmail = cursor.getString(cursor.getColumnIndex(Email.DATA));  
                    jsonObject.put("mobileEmail", mobileEmail);  
                }  
  
                //         
                else if (emailType == Email.TYPE_MOBILE) {  
                    String mobileEmail = cursor.getString(cursor.getColumnIndex(Email.DATA));  
                    jsonObject.put("mobileEmail", mobileEmail);  
                }  
            }  
            //   event    
            if (Event.CONTENT_ITEM_TYPE.equals(mimetype)) {  
                //         
                int eventType = cursor.getInt(cursor.getColumnIndex(Event.TYPE));  
                //     
                if (eventType == Event.TYPE_BIRTHDAY) {  
                    String birthday = cursor.getString(cursor.getColumnIndex(Event.START_DATE));  
                    jsonObject.put("birthday", birthday);  
                }  
                //        
                if (eventType == Event.TYPE_ANNIVERSARY) {  
                    String anniversary = cursor.getString(cursor.getColumnIndex(Event.START_DATE));  
                    jsonObject.put("anniversary", anniversary);  
                }  
            }  
            //       
            if (Im.CONTENT_ITEM_TYPE.equals(mimetype)) {  
                //           
                int protocal = cursor.getInt(cursor.getColumnIndex(Im.PROTOCOL));  
                if (Im.TYPE_CUSTOM == protocal) {  
                    String workMsg = cursor.getString(cursor.getColumnIndex(Im.DATA));  
                    jsonObject.put("workMsg", workMsg);  
                }  
  
                else if (Im.PROTOCOL_MSN == protocal) {  
                    String workMsg = cursor.getString(cursor.getColumnIndex(Im.DATA));  
                    jsonObject.put("workMsg", workMsg);  
                }  
                if (Im.PROTOCOL_QQ == protocal) {  
                    String instantsMsg = cursor.getString(cursor.getColumnIndex(Im.DATA));  
                    jsonObject.put("instantsMsg", instantsMsg);  
                }  
            }  
            //         
            if (Note.CONTENT_ITEM_TYPE.equals(mimetype)) {  
                String remark = cursor.getString(cursor.getColumnIndex(Note.NOTE));  
                jsonObject.put("remark", remark);  
            }  
            //         
            if (Nickname.CONTENT_ITEM_TYPE.equals(mimetype)) {  
                String nickName = cursor.getString(cursor.getColumnIndex(Nickname.NAME));  
                jsonObject.put("nickName", nickName);  
            }  
            //         
            if (Organization.CONTENT_ITEM_TYPE.equals(mimetype)) {  
                //         
                int orgType = cursor.getInt(cursor.getColumnIndex(Organization.TYPE));  
                //     
                if (orgType == Organization.TYPE_CUSTOM) {  
                    //           if (orgType == Organization.TYPE_WORK) {  
                    String company = cursor.getString(cursor.getColumnIndex(Organization.COMPANY));  
                    jsonObject.put("company", company);  
                    String jobTitle = cursor.getString(cursor.getColumnIndex(Organization.TITLE));  
                    jsonObject.put("jobTitle", jobTitle);  
                    String department = cursor.getString(cursor.getColumnIndex(Organization.DEPARTMENT));  
                    jsonObject.put("department", department);  
                }  
            }  
            //         
            if (Website.CONTENT_ITEM_TYPE.equals(mimetype)) {  
                //         
                int webType = cursor.getInt(cursor.getColumnIndex(Website.TYPE));  
                //     
                if (webType == Website.TYPE_CUSTOM) {  
                    String home = cursor.getString(cursor.getColumnIndex(Website.URL));  
                    jsonObject.put("home", home);  
                }  
                //     
                else if (webType == Website.TYPE_HOME) {  
                    String home = cursor.getString(cursor.getColumnIndex(Website.URL));  
                    jsonObject.put("home", home);  
                }  
  
                //       
                if (webType == Website.TYPE_HOMEPAGE) {  
                    String homePage = cursor.getString(cursor.getColumnIndex(Website.URL));  
                    jsonObject.put("homePage", homePage);  
                }  
                //       
                if (webType == Website.TYPE_WORK) {  
                    String workPage = cursor.getString(cursor.getColumnIndex(Website.URL));  
                    jsonObject.put("workPage", workPage);  
                }  
            }  
            //         
            if (StructuredPostal.CONTENT_ITEM_TYPE.equals(mimetype)) {  
                //         
                int postalType = cursor.getInt(cursor.getColumnIndex(StructuredPostal.TYPE));  
                //         
                if (postalType == StructuredPostal.TYPE_WORK) {  
                    String street = cursor.getString(cursor.getColumnIndex(StructuredPostal.STREET));  
                    jsonObject.put("street", street);  
                    String ciry = cursor.getString(cursor.getColumnIndex(StructuredPostal.CITY));  
                    jsonObject.put("ciry", ciry);  
                    String box = cursor.getString(cursor.getColumnIndex(StructuredPostal.POBOX));  
                    jsonObject.put("box", box);  
                    String area = cursor.getString(cursor.getColumnIndex(StructuredPostal.NEIGHBORHOOD));  
                    jsonObject.put("area", area);  
                    String state = cursor.getString(cursor.getColumnIndex(StructuredPostal.REGION));  
                    jsonObject.put("state", state);  
                    String zip = cursor.getString(cursor.getColumnIndex(StructuredPostal.POSTCODE));  
                    jsonObject.put("zip", zip);  
                    String country = cursor.getString(cursor.getColumnIndex(StructuredPostal.COUNTRY));  
                    jsonObject.put("country", country);  
                }  
                //         
                if (postalType == StructuredPostal.TYPE_HOME) {  
                    String homeStreet = cursor.getString(cursor.getColumnIndex(StructuredPostal.STREET));  
                    jsonObject.put("homeStreet", homeStreet);  
                    String homeCity = cursor.getString(cursor.getColumnIndex(StructuredPostal.CITY));  
                    jsonObject.put("homeCity", homeCity);  
                    String homeBox = cursor.getString(cursor.getColumnIndex(StructuredPostal.POBOX));  
                    jsonObject.put("homeBox", homeBox);  
                    String homeArea = cursor.getString(cursor.getColumnIndex(StructuredPostal.NEIGHBORHOOD));  
                    jsonObject.put("homeArea", homeArea);  
                    String homeState = cursor.getString(cursor.getColumnIndex(StructuredPostal.REGION));  
                    jsonObject.put("homeState", homeState);  
                    String homeZip = cursor.getString(cursor.getColumnIndex(StructuredPostal.POSTCODE));  
                    jsonObject.put("homeZip", homeZip);  
                    String homeCountry = cursor.getString(cursor.getColumnIndex(StructuredPostal.COUNTRY));  
                    jsonObject.put("homeCountry", homeCountry);  
                }  
                //         
                if (postalType == StructuredPostal.TYPE_OTHER) {  
                    String otherStreet = cursor.getString(cursor.getColumnIndex(StructuredPostal.STREET));  
                    jsonObject.put("otherStreet", otherStreet);  
                    String otherCity = cursor.getString(cursor.getColumnIndex(StructuredPostal.CITY));  
                    jsonObject.put("otherCity", otherCity);  
                    String otherBox = cursor.getString(cursor.getColumnIndex(StructuredPostal.POBOX));  
                    jsonObject.put("otherBox", otherBox);  
                    String otherArea = cursor.getString(cursor.getColumnIndex(StructuredPostal.NEIGHBORHOOD));  
                    jsonObject.put("otherArea", otherArea);  
                    String otherState = cursor.getString(cursor.getColumnIndex(StructuredPostal.REGION));  
                    jsonObject.put("otherState", otherState);  
                    String otherZip = cursor.getString(cursor.getColumnIndex(StructuredPostal.POSTCODE));  
                    jsonObject.put("otherZip", otherZip);  
                    String otherCountry = cursor.getString(cursor.getColumnIndex(StructuredPostal.COUNTRY));  
                    jsonObject.put("otherCountry", otherCountry);  
                }  
            }  
        }  
        cursor.close();  
        Log.i("contactData", contactData.toString());  
        return contactData.toString();  
    }  
}