0

連絡先を選択して電話番号を取得するコードを取得しようとしています。エミュレーター(Androidバージョン2.3.3)と兄弟の電話(Jelly bean)でうまく機能するコードを見つけましたが、自分のデバイス(Android 2.3.4)では機能しません

コードは次のとおりです。連絡先に移動するには

    public void onClick(View arg0) {
        // TODO Auto-generated method stub
         Intent intent = new Intent(Intent.ACTION_GET_CONTENT);
         intent.setType(ContactsContract.CommonDataKinds.Phone.CONTENT_ITEM_TYPE);
         startActivityForResult(intent, 1);      
    }

連絡先から戻る場合:

@Override
protected void onActivityResult(int requestCode, int resultCode, Intent data) {

    if (data != null) {
        Uri uri = data.getData();

        if (uri != null) {
            Cursor c = null;
            try {
                c = getContentResolver().query(uri, new String[]{ContactsContract.CommonDataKinds.Phone.NUMBER},
                        null, null, null);

                if (c != null && c.moveToFirst()) {
                    String number = c.getString(0);
                    //int type = c.getInt(1);
                    showSelectedNumber(0, number);
                }
            } finally {
                if (c != null) {
                    c.close();
                }
            }
        }
    }
}

public void showSelectedNumber(int type, String number) {
    Toast.makeText(this,number, Toast.LENGTH_LONG).show();      
}

繰り返しますが、これはエミュレーター (android 2.3.4) と Jelly bean では機能しますが、私のデバイス (android 2.3.5) では機能しません。

これはログから出てくるものです:

10-10 22:07:15.775: E/AndroidRuntime(5075): FATAL EXCEPTION: main
10-10 22:07:15.775: E/AndroidRuntime(5075): java.lang.RuntimeException: Failure delivering result ResultInfo{who=null, request=1, result=-1, data=Intent { dat=content://com.android.contacts/data/2848 (has extras) }} to activity {com.example.omer/com.example.omer.SmsInfo}: java.lang.SecurityException: Permission Denial: reading com.android.providers.contacts.HtcContactsProvider2 uri content://com.android.contacts/data/2848 from pid=5075, uid=10125 requires android.permission.READ_CONTACTS
10-10 22:07:15.775: E/AndroidRuntime(5075):     at android.app.ActivityThread.deliverResults(ActivityThread.java)
10-10 22:07:15.775: E/AndroidRuntime(5075):     at android.app.ActivityThread.handleSendResult(ActivityThread.java)
10-10 22:07:15.775: E/AndroidRuntime(5075):     at android.app.ActivityThread.access$2000(ActivityThread.java)
10-10 22:07:15.775: E/AndroidRuntime(5075):     at android.app.ActivityThread$H.handleMessage(ActivityThread.java)
10-10 22:07:15.775: E/AndroidRuntime(5075):     at android.os.Handler.dispatchMessage(Handler.java)
10-10 22:07:15.775: E/AndroidRuntime(5075):     at android.os.Looper.loop(Looper.java)
10-10 22:07:15.775: E/AndroidRuntime(5075):     at android.app.ActivityThread.main(ActivityThread.java)
10-10 22:07:15.775: E/AndroidRuntime(5075):     at java.lang.reflect.Method.invokeNative(Native Method)
10-10 22:07:15.775: E/AndroidRuntime(5075):     at java.lang.reflect.Method.invoke(Method.java:507)
10-10 22:07:15.775: E/AndroidRuntime(5075):     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java)
10-10 22:07:15.775: E/AndroidRuntime(5075):     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java)
10-10 22:07:15.775: E/AndroidRuntime(5075):     at dalvik.system.NativeStart.main(Native Method)
10-10 22:07:15.775: E/AndroidRuntime(5075): Caused by: java.lang.SecurityException: Permission Denial: reading com.android.providers.contacts.HtcContactsProvider2 uri content://com.android.contacts/data/2848 from pid=5075, uid=10125 requires android.permission.READ_CONTACTS
10-10 22:07:15.775: E/AndroidRuntime(5075):     at android.os.Parcel.readException(Parcel.java)
10-10 22:07:15.775: E/AndroidRuntime(5075):     at android.database.DatabaseUtils.readExceptionFromParcel(DatabaseUtils.java)
10-10 22:07:15.775: E/AndroidRuntime(5075):     at android.database.DatabaseUtils.readExceptionFromParcel(DatabaseUtils.java)
10-10 22:07:15.775: E/AndroidRuntime(5075):     at android.content.ContentProviderProxy.bulkQueryInternal(ContentProviderNative.java)
10-10 22:07:15.775: E/AndroidRuntime(5075):     at android.content.ContentProviderProxy.query(ContentProviderNative.java)
10-10 22:07:15.775: E/AndroidRuntime(5075):     at android.content.ContentResolver.query(ContentResolver.java)
10-10 22:07:15.775: E/AndroidRuntime(5075):     at com.example.omer.SmsInfo.onActivityResult(SmsInfo.java:87)
10-10 22:07:15.775: E/AndroidRuntime(5075):     at android.app.Activity.dispatchActivityResult(Activity.java)

10-10 22:07:15.775: E/AndroidRuntime(5075): ... 12 もっと見る

4

2 に答える 2

1

わかりました。マニフェスト ファイルにアクセス許可を追加する必要がありました。

<uses-permission android:name="android.permission.READ_CONTACTS"/>
于 2012-10-10T20:13:03.920 に答える
0

エラーメッセージによると:

java.lang.RuntimeException: 結果 ResultInfo{who=null, request=1, result=-1, data=Intent { dat=content://com.android.contacts/data/2848 (エクストラあり) }} の配信に失敗しましたアクティビティ {com.example.omer/com.example.omer.SmsInfo}: java.lang.SecurityException: 許可拒否: com.android.providers.contacts.HtcContactsProvider2 uri content://com.android.contacts/data/2848 の読み取りpid=5075 から、uid=10125 には android.permission.READ_CONTACTS が必要です

権限を追加する必要がありますandroid.permission.READ_CONTACTS

于 2012-10-10T20:11:55.930 に答える