2016-04-05 16 views
4

TelephonyManagerを使用してユーザーの電話事業者を取得できます。この名前を使用して、事業者から受け取ったテキストを取得する必要があります。 AndroidのContextResolver.query()メソッドでSQL where節のようなものを使用するにはどうすればよいですか?ユーザーが受け取ったすべてのテキストメッセージを取得するコードは次のとおりです。ユーザーの電話オペレータからメッセージを取得するには、それを調整する必要があります。電話オペレータからSMSメッセージを取得するにはどうすればよいですか?

public void fetchSMS() { 

    TelephonyManager tMgr = (TelephonyManager) getSystemService(Context.TELEPHONY_SERVICE); 
    String operator=tMgr.getNetworkOperatorName(); 
    Uri mSmsinboxQueryUri = Uri.parse("content://sms/inbox"); 
    String[] cols = new String[]{"_id", "thread_id", "address", "person", "date", "body", "type"}; 
    Cursor cursor1 = getContentResolver().query(
      mSmsinboxQueryUri, 
      cols, null, null, null); 
    if (cursor1!=null && cursor1.moveToFirst()) { 
     do { 
      String address = cursor1.getString(cursor1 
        .getColumnIndex(cols[2])); 
      //String address2=(address.split("-"))[1]; 

       String date = cursor1.getString(cursor1 
         .getColumnIndex(cols[4])); 
       String msg = cursor1.getString(cursor1 
         .getColumnIndex(cols[5])); 
       String type = cursor1.getString(cursor1 
         .getColumnIndex(cols[6])); 

       smsLog.append("\n" + "Address:").append(address).append("\n" + "Date:").append(date).append("\n" + "Message:").append(msg).append("\n" + "Type:").append(type).append("\n\n"); 
      cursor1.moveToNext(); 
     } 
     while (!cursor1.isAfterLast()); 
     cursor1.close(); 
    } 
} 
+0

特定のオペレーターがSMSを送信できるすべてのアドレスを知っている場合を除いて、これを確実に行うことはできません。 SMS表には、オペレーター名を保持する列はなく、オペレーターからのメッセージがメッセージ本文にその名前を持つという保証はありません。 –

+0

充電(プリペイド電話)後に通信事業者からメッセージを受信すると、特定の住所のテキストが受信されます(電話オペレータはDocomoと呼ばれ、送信者にはTA-Docomoとして送信されます) 。他の演算子でも同じです。 query()メソッドにwhere句を追加する方法を知りたいだけです。 –

+0

これは誰にも当てはまるわけではありませんが、単純なwhere句が必要な場合、クエリは次のようになります: 'query(mSmsinboxQueryUri、cols、" LIKE '% "+ operator +"%' " 、ヌル、ヌル) '。 –

答えて

1

あなたにとって役に立つかもしれません。

More Information refer this page

SmsBroadcastReceiver.java

これは意図濾過SMSメッセージを受信するBroadcastReceiverです。 onReceiveでは、SMSメッセージバンドルを抽出してトーストメッセージを表示し、SMS受信トレイリストにSMSメッセージを追加してUIを更新します。 SMSメッセージが到着すると、受信トレイは自動的にリフレッシュされます。

public class SmsBroadcastReceiver extends BroadcastReceiver { 

    public static final String SMS_BUNDLE = "pdus"; 

    public void onReceive(Context context, Intent intent) { 
     Bundle intentExtras = intent.getExtras(); 
     if (intentExtras != null) { 
      Object[] sms = (Object[]) intentExtras.get(SMS_BUNDLE); 
      String smsMessageStr = ""; 
      for (int i = 0; i < sms.length; ++i) { 
       SmsMessage smsMessage = SmsMessage.createFromPdu((byte[]) sms[i]); 

       String smsBody = smsMessage.getMessageBody().toString(); 
       String address = smsMessage.getOriginatingAddress(); 

       smsMessageStr += "SMS From: " + address + "\n"; 
       smsMessageStr += smsBody + "\n"; 
      } 
      Toast.makeText(context, smsMessageStr, Toast.LENGTH_SHORT).show(); 

      //this will update the UI with message 
      SmsActivity inst = SmsActivity.instance(); 
      inst.updateList(smsMessageStr); 
     } 
    } 
} 

SmsActivity.java これは、SMSアプリケーションのメインのAndroid活動です。 SMSの受信トレイとして機能します。 SMSメッセージを表示するListViewがあります。 onCreate内部SMS受信トレイにあるすべてのメッセージをUriから読み込み、ListViewを使用して表示します。

public class SmsActivity extends Activity implements OnItemClickListener { 

    private static SmsActivity inst; 
    ArrayList<String> smsMessagesList = new ArrayList<String>(); 
    ListView smsListView; 
    ArrayAdapter arrayAdapter; 

    public static SmsActivity instance() { 
     return inst; 
    } 

    @Override 
    public void onStart() { 
     super.onStart(); 
     inst = this; 
    } 

    @Override 
    protected void onCreate(Bundle savedInstanceState) { 
     super.onCreate(savedInstanceState); 
     setContentView(R.layout.activity_sms); 
     smsListView = (ListView) findViewById(R.id.SMSList); 
     arrayAdapter = new ArrayAdapter<String>(this, android.R.layout.simple_list_item_1, smsMessagesList); 
     smsListView.setAdapter(arrayAdapter); 
     smsListView.setOnItemClickListener(this); 

     refreshSmsInbox(); 
    } 

    public void refreshSmsInbox() { 
     ContentResolver contentResolver = getContentResolver(); 
     Cursor smsInboxCursor = contentResolver.query(Uri.parse("content://sms/inbox"), null, null, null, null); 
     int indexBody = smsInboxCursor.getColumnIndex("body"); 
     int indexAddress = smsInboxCursor.getColumnIndex("address"); 
     if (indexBody < 0 || !smsInboxCursor.moveToFirst()) return; 
     arrayAdapter.clear(); 
     do { 
      String str = "SMS From: " + smsInboxCursor.getString(indexAddress) + 
        "\n" + smsInboxCursor.getString(indexBody) + "\n"; 
      arrayAdapter.add(str); 
     } while (smsInboxCursor.moveToNext()); 
    } 

    public void updateList(final String smsMessage) { 
     arrayAdapter.insert(smsMessage, 0); 
     arrayAdapter.notifyDataSetChanged(); 
    } 

    public void onItemClick(AdapterView<?> parent, View view, int pos, long id) { 
     try { 
      String[] smsMessages = smsMessagesList.get(pos).split("\n"); 
      String address = smsMessages[0]; 
      String smsMessage = ""; 
      for (int i = 1; i < smsMessages.length; ++i) { 
       smsMessage += smsMessages[i]; 
      } 

      String smsMessageStr = address + "\n"; 
      smsMessageStr += smsMessage; 
      Toast.makeText(this, smsMessageStr, Toast.LENGTH_SHORT).show(); 
     } catch (Exception e) { 
      e.printStackTrace(); 
     } 
    } 
} 
+0

いいえ、これは私が探していたものではありませんが、それにもかかわらず、知る価値のあるものです。ありがとう! –

+0

私の答えがあなたに解決策を与えるならば。 upvoteを与え、私の答えを受け入れました。ありがとう。@ SubravetiSuraj –

関連する問題