編輯:關於Android編程
Android收到短信時會廣播android.provider.Telephony.SMS_RECEIVED消息,因此只要定義一個Receiver,收聽該消息,就能接收短信。
<receiver android:name=".smsReceiver" > <intent-filter> <action android:name="android.provider.Telephony.SMS_RECEIVED" /> </intent-filter> </receiver>
還可以為intent-filter加上一個優先級:
<intent-filter android:priority="100">
這樣,由於優先級較高,應用將先於系統接收到android.provider.Telephony.SMS_RECEIVED消息。
Java文件:
package com.hzhi.smsReceiver; import java.text.SimpleDateFormat; import java.util.Date; import android.content.BroadcastReceiver; import android.content.Context; import android.content.Intent; import android.os.Bundle; import android.telephony.SmsMessage; import android.util.Log; public class smsReceiver extends BroadcastReceiver { @Override public void onReceive(Context context, Intent intent) { // 短信內容 StringBuilder strBody = new StringBuilder(); // 短信時間 String strTime = new String(); // 短信發件人 StringBuilder number = new StringBuilder(); SimpleDateFormat formatter = new SimpleDateFormat("yyyy-MM-dd hh:mm:ss"); Bundle bundle = intent.getExtras(); if (bundle != null) { Object[] _pdus = (Object[]) bundle.get("pdus"); SmsMessage[] message = new SmsMessage[_pdus.length]; for (int i = 0; i < _pdus.length; i++) { message[i] = SmsMessage.createFromPdu((byte[]) _pdus[i]); } for (SmsMessage currentMessage : message) { strBody.append(currentMessage.getDisplayMessageBody()); number.append(currentMessage.getDisplayOriginatingAddress()); strTime = formatter.format(new Date(currentMessage.getTimestampMillis())); } String smsBody = strBody.toString(); String smsNumber = number.toString(); Log.v("NUMBER=", smsNumber); Log.v("TIME=", strTime); Log.v("BODY=", smsBody); // 取消消息 this.abortBroadcast(); } } }
接收到消息後,通過Intent.getExtras()方法獲得Intent的Extras(Bundle變量),再使用Bundle.get("pdus")得到短信數組。為什麼是短信數組呢?這是因為有些短信內容比較長,所以需要一個數組來存儲。對數組中的每一個元素,再分別取出短信內容、短信來源號碼、短信時間。其中,這些元素的短信來源號碼和短信時間都是一樣的,短信內容不一樣,需要拼接起來,構成一條完整的短信的內容。
最後,this.abortBroadcast()取消android.provider.Telephony.SMS_RECEIVED消息。如果為intent-filter設置了較高的優先級,應用先於系統接收到android.provider.Telephony.SMS_RECEIVED消息,然後再將該消息丟棄,這樣,系統就不會收到android.provider.Telephony.SMS_RECEIVED消息,也不會發出短信的提示音、震動等。如果沒有設置優先級,系統將首先收到android.provider.Telephony.SMS_RECEIVED消息,發出短信的提示音、震動等,然後應用再收到短信。
// 發送短信 public void sendMsg(){ String content = edtSend.getText().toString(); SmsManager smsManager = SmsManager.getDefault(); List<String> divideContents = smsManager.divideMessage(content); for (String text : divideContents) { smsManager.sendTextMessage(smsWidget.str_number, null, text, null, null); } }
首先獲得一個SmsManager實例;再用divideMessage()方法將短信內容(content)劃分成幾個部分,這是因為如果短信內容太長,可能會超出允許發送的最大長度,這時就需要把短信內容劃分成幾個字符串,一般情況下,內容都不會超過最大長度,所以還是一個字符串;最後,對所有的字符串,使用sendTextMessage()方法發送,其中smsWidget.str_number是對方號碼,text是每一個字符串。
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持本站。
Activity棧主要用於管理Activity的切換。當使用Intent跳轉至某個目標Activity,需要根據目標Activity的加載模式來加載。Activity一共
安卓6.0 Marshmallow棉花糖版本雖然普及率依然可憐至極,但這並不能阻擋Google開發並推出下一個版本Android N,預計將會是
我們編寫的是Andorid的HTTP協議多線程斷點下載應用程序。直接使用單線程下載HTTP文件對我們來說是一件非常簡單的事。那麼,多線程斷點需要什麼功能?1.多線程下載,
之前寫的第一篇Fragment實例,和大多數人一開始學的一樣,都是通過FragmentTransaction的replace方法來實現,replace方法相