Ich versuche, eine Anwendung zur Überwachung eingehender SMS-Nachrichten zu erstellen und ein Programm über eingehende SMS zu starten, außerdem soll es den Inhalt der SMS lesen.
Arbeitsablauf:
public class SmsListener extends BroadcastReceiver{
private SharedPreferences preferences;
@Override
public void onReceive(Context context, Intent intent) {
// TODO Auto-generated method stub
if(intent.getAction().equals("android.provider.Telephony.SMS_RECEIVED")){
Bundle bundle = intent.getExtras(); //---get the SMS message passed in---
SmsMessage[] msgs = null;
String msg_from;
if (bundle != null){
//---retrieve the SMS message received---
try{
Object[] pdus = (Object[]) bundle.get("pdus");
msgs = new SmsMessage[pdus.length];
for(int i=0; i<msgs.length; i++){
msgs[i] = SmsMessage.createFromPdu((byte[])pdus[i]);
msg_from = msgs[i].getOriginatingAddress();
String msgBody = msgs[i].getMessageBody();
}
}catch(Exception e){
// Log.d("Exception caught",e.getMessage());
}
}
}
}
}
Hinweis: Fügen Sie in Ihrer Manifestdatei die BroadcastReceiver-
<receiver android:name=".listener.SmsListener">
<intent-filter>
<action android:name="android.provider.Telephony.SMS_RECEIVED" />
</intent-filter>
</receiver>
Fügen Sie diese Berechtigung hinzu:
<uses-permission android:name="android.permission.RECEIVE_SMS" />
Beachten Sie, dass Ihr Code auf einigen Geräten ohne android:priority="1000" im Absichtsfilter nicht funktionieren wird:
<receiver android:name=".listener.SmsListener">
<intent-filter android:priority="1000">
<action android:name="android.provider.Telephony.SMS_RECEIVED" />
</intent-filter>
</receiver>
Und hier sind einige Optimierungen:
public class SmsListener extends BroadcastReceiver{
@Override
public void onReceive(Context context, Intent intent) {
if (Telephony.Sms.Intents.SMS_RECEIVED_ACTION.equals(intent.getAction())) {
for (SmsMessage smsMessage : Telephony.Sms.Intents.getMessagesFromIntent(intent)) {
String messageBody = smsMessage.getMessageBody();
}
}
}
}
Anmerkung:
Der Wert muss eine ganze Zahl sein, z. B. "100". Höhere Zahlen haben eine höhere Priorität. Der Standardwert ist 0. Der Wert muss größer als -1000 und kleiner als 1000 sein.
@Mike M. und ich haben ein Problem mit der akzeptierten Antwort gefunden (siehe unsere Kommentare):
Es macht im Grunde keinen Sinn, die for-Schleife zu durchlaufen, wenn wir die mehrteilige Nachricht nicht jedes Mal verketten:
for (int i = 0; i < msgs.length; i++) {
msgs[i] = SmsMessage.createFromPdu((byte[])pdus[i]);
msg_from = msgs[i].getOriginatingAddress();
String msgBody = msgs[i].getMessageBody();
}
Beachten Sie, dass wir msgBody
einfach auf den String-Wert des jeweiligen Teils der Nachricht setzen, egal bei welchem Index wir uns befinden, was den ganzen Sinn der Schleife durch die verschiedenen Teile der SMS-Nachricht nutzlos macht, da er einfach auf den allerletzten Indexwert gesetzt wird. Stattdessen sollten wir +=
verwenden, oder wie Mike bemerkte, StringBuilder
:
Alles in allem sieht mein SMS-Empfangscode so aus:
if (myBundle != null) {
Object[] pdus = (Object[]) myBundle.get("pdus"); // pdus is key for SMS in bundle
//Object [] pdus now contains array of bytes
messages = new SmsMessage[pdus.length];
for (int i = 0; i < messages.length; i++) {
messages[i] = SmsMessage.createFromPdu((byte[]) pdus[i]); //Returns one message, in array because multipart message due to sms max char
Message += messages[i].getMessageBody(); // Using +=, because need to add multipart from before also
}
contactNumber = messages[0].getOriginatingAddress(); //This could also be inside the loop, but there is no need
}
Ich möchte diese Antwort nur für den Fall geben, dass jemand anderes die gleiche Verwirrung hat.