Android極速開發之發送短信
1、調用系統已有程序發短信功能
/**
* @param phoneNumber
* @param message
*/
public void doSendSMSTo(String phoneNumber,String message){
if(PhoneNumberUtils.isGlobalPhoneNumber(phoneNumber)){
Intent intent = new Intent(Intent.ACTION_SENDTO, Uri.parse("smsto:"+phoneNumber));
intent.putExtra("sms_body", message);
startActivity(intent);
}
}
2、調用API來實現發送短信
SMS涉及的主要類SmsManager
實現SMS主要用到SmsManager類,該類繼承自java.lang.Object類,下面我們介紹一下該類的主要成員。
公有方法:
- ArrayList<String> divideMessage (String text)
當短信超過SMS消息的最大長度時,將短信分割為幾塊。
參數:text——初始的消息,不能為空
返回值:有序的ArrayList<String>,可以重新組合為初始的消息
- static SmsManager getDefault ()
獲取SmsManager的默認實例。
返回值:SmsManager的默認實例
- void SendDataMessage (String destinationAddress, String scAddress, short destinationPort, byte[] data,PendingIntent sentIntent, PendingIntent deliveryIntent)
發送一個基于SMS的數據到指定的應用程序端口。
參數:
1)、destinationAddress——消息的目標地址
2)、scAddress——服務中心的地址or為空使用當前默認的SMSC
3)、destinationPort——消息的目標端口號
4)、data——消息的主體,即消息要發送的數據
5)、sentIntent——如果不為空,當消息成功發送或失敗這個PendingIntent就廣播。結果代碼是Activity.RESULT_OK表示成功,或RESULT_ERROR_GENERIC_FAILURE、RESULT_ERROR_RADIO_OFF、RESULT_ERROR_NULL_PDU之一表示錯誤。對應RESULT_ERROR_GENERIC_FAILURE,sentIntent可能包括額外的“錯誤代碼”包含一個無線電廣播技術特定的值,通常只在修復故障時有用。 每一個基于SMS的應用程序控制檢測sentIntent。如果sentIntent是空,調用者將檢測所有未知的應用程序,這將導致在檢測的時候發送較小數量的SMS。
6)、deliveryIntent——如果不為空,當消息成功傳送到接收者這個PendingIntent就廣播。
異常:如果destinationAddress或data是空時,拋出IllegalArgumentException異常。
- void sendMultipartTextMessage (String destinationAddress, String scAddress, ArrayList<String> parts,ArrayList<PendingIntent> sentIntents, ArrayList<PendingIntent> deliverIntents)
發送一個基于SMS的多部分文本,調用者應用已經通過調用 divideMessage (String text)將消息分割成正確的大小。
參數:
1)、destinationAddress——消息的目標地址
2)、scAddress——服務中心的地址or為空使用當前默認的SMSC
3)、parts——有序的ArrayList<String>,可以重新組合為初始的消息
4)、sentIntents——跟 SendDataMessage 方法中一樣,只不過這里的是一組PendingIntent
5)、deliverIntents——跟 SendDataMessage 方法中一樣,只不過這里的是一組PendingIntent
異常:如果destinationAddress或data是空時,拋出IllegalArgumentException異常。
- void sendTextMessage
(String destinationAddress, String scAddress, String text, PendingIntent sentIntent,PendingIntent deliveryIntent)
發送一個基于SMS的文本。參數的意義和異常前面的已存在的一樣,不再累述。
代碼封裝如下
SMSMethod 發送短信的單例
public class SMSMethod {
private static SMSMethod mSMSmsMethod;
/* 自定義ACTION常數,作為廣播的Intent Filter識別常數 */
public static String SMS_SEND_ACTIOIN = "SMS_SEND_ACTIOIN";
public static String SMS_DELIVERED_ACTION = "SMS_DELIVERED_ACTION";
/* 建立兩個mServiceReceiver對象,作為類成員變量 */
private SMSReceiver mSendSMSReceiver, mDeliveredSMSReceiver;
private Context mContext;
private SMSMethod(Context context){
mContext=context;
registerReceiver();
}
public static SMSMethod getInstance(Context context){
if (mSMSmsMethod==null){
synchronized (SMSMethod.class){
if (mSMSmsMethod==null){
mSMSmsMethod=new SMSMethod(context);
}
}
}
return mSMSmsMethod;
}
/**
* 注冊
*/
public void registerReceiver(){
/* 自定義IntentFilter為SENT_SMS_ACTIOIN Receiver */
IntentFilter mFilter01;
mFilter01 = new IntentFilter(SMS_SEND_ACTIOIN);
mSendSMSReceiver = new SMSReceiver();
mContext.registerReceiver(mSendSMSReceiver, mFilter01);
/* 自定義IntentFilter為DELIVERED_SMS_ACTION Receiver */
mFilter01 = new IntentFilter(SMS_DELIVERED_ACTION);
mDeliveredSMSReceiver = new SMSReceiver();
mContext.registerReceiver(mDeliveredSMSReceiver, mFilter01);
}
public void unregisterReceiver(){
/* 取消注冊自定義Receiver */
if (mSendSMSReceiver!=null){
mContext.unregisterReceiver(mSendSMSReceiver);
}
if (mDeliveredSMSReceiver!=null) {
mContext.unregisterReceiver(mDeliveredSMSReceiver);
}
}
public void SendMessage(String strDestAddress,String strMessage){
/* 建立SmsManager對象 */
SmsManager smsManager = SmsManager.getDefault();
try {
/* 建立自定義Action常數的Intent(給PendingIntent參數之用) */
Intent itSend = new Intent(SMS_SEND_ACTIOIN);
Intent itDeliver = new Intent(SMS_DELIVERED_ACTION);
/* sentIntent參數為傳送后接受的廣播信息PendingIntent */
PendingIntent mSendPI = PendingIntent.getBroadcast(mContext, 0, itSend, 0);
/* deliveryIntent參數為送達后接受的廣播信息PendingIntent */
PendingIntent mDeliverPI = PendingIntent.getBroadcast(mContext, 0, itDeliver, 0);
List<String> divideContents = smsManager.divideMessage(strMessage);
for (String text:divideContents) {
/* 發送SMS短信,注意倒數的兩個PendingIntent參數 */
smsManager.sendTextMessage(strDestAddress, null, text, mSendPI, mDeliverPI);
}
}catch(Exception e) {
e.printStackTrace();
}
}
public void SendMessage2(String strDestAddress,String strMessage){
ArrayList<PendingIntent> sentPendingIntents = new ArrayList<PendingIntent>();
ArrayList<PendingIntent> deliveredPendingIntents = new ArrayList<PendingIntent>();
/* 建立SmsManager對象 */
SmsManager smsManager = SmsManager.getDefault();
try {
/* 建立自定義Action常數的Intent(給PendingIntent參數之用) */
Intent itSend = new Intent(SMS_SEND_ACTIOIN);
Intent itDeliver = new Intent(SMS_DELIVERED_ACTION);
/* sentIntent參數為傳送后接受的廣播信息PendingIntent */
PendingIntent mSendPI = PendingIntent.getBroadcast(mContext, 0, itSend, 0);
/* deliveryIntent參數為送達后接受的廣播信息PendingIntent */
PendingIntent mDeliverPI = PendingIntent.getBroadcast(mContext, 0, itDeliver, 0);
ArrayList<String> mSMSMessage = smsManager.divideMessage(strMessage);
for (int i = 0; i < mSMSMessage.size(); i++) {
sentPendingIntents.add(i, mSendPI);
deliveredPendingIntents.add(i, mDeliverPI);
}
/* 發送SMS短信,注意倒數的兩個PendingIntent參數 */
smsManager.sendMultipartTextMessage(strDestAddress,null,mSMSMessage ,sentPendingIntents,deliveredPendingIntents);
}catch(Exception e) {
e.printStackTrace();
}
}
}
短信發送狀態監聽
public class SMSReceiver extends BroadcastReceiver{
@Override
public void onReceive(Context context, Intent intent) {
if (intent.getAction().equals(SMSMethod.SMS_SEND_ACTIOIN)){
try{
/* android.content.BroadcastReceiver.getResultCode()方法 */
//Retrieve the current result code, as set by the previous receiver.
switch (getResultCode()){
case Activity.RESULT_OK:
Toast.makeText(context, "短信發送成功", Toast.LENGTH_SHORT).show();
break;
case SmsManager.RESULT_ERROR_GENERIC_FAILURE:
Toast.makeText(context, "短信發送失敗", Toast.LENGTH_SHORT).show();
break;
case SmsManager.RESULT_ERROR_RADIO_OFF:
break;
case SmsManager.RESULT_ERROR_NULL_PDU:
break;
}
}catch (Exception e){
}
} else if(intent.getAction().equals(SMSMethod.SMS_DELIVERED_ACTION)){
/* android.content.BroadcastReceiver.getResultCode()方法 */
switch(getResultCode()){
case Activity.RESULT_OK:
Toast.makeText(context, "短信已送達", Toast.LENGTH_SHORT).show();
break;
case SmsManager.RESULT_ERROR_GENERIC_FAILURE:
/* 短信未送達 */
Toast.makeText(context, "短信未送達", Toast.LENGTH_SHORT).show();
break;
case SmsManager.RESULT_ERROR_RADIO_OFF:
break;
case SmsManager.RESULT_ERROR_NULL_PDU:
break;
}
}
}
}
在AndroidManifest.xml中添加監聽
<!-- 短信發送送達--><receiver android:name=".sms.SMSReceiver"/>
- 一些例子
public void sendTextMessage(View view){
SMSMethod.getInstance(this).SendMessage("這里填寫手機號碼","測試短信.....Javen");
}
public void sendMultipartTextMessage(View view){
SMSMethod.getInstance(this).SendMessage2("這里填寫手機號碼", "測試短信......Javen");
}
@Override
protected void onPause() {
SMSMethod.getInstance(this).unregisterReceiver();
super.onPause();
}
1、調用系統已有程序發短信功能
/**
* @param phoneNumber
* @param message
*/
public void doSendSMSTo(String phoneNumber,String message){
if(PhoneNumberUtils.isGlobalPhoneNumber(phoneNumber)){
Intent intent = new Intent(Intent.ACTION_SENDTO, Uri.parse("smsto:"+phoneNumber));
intent.putExtra("sms_body", message);
startActivity(intent);
}
}
2、調用API來實現發送短信
SMS涉及的主要類SmsManager
實現SMS主要用到SmsManager類,該類繼承自java.lang.Object類,下面我們介紹一下該類的主要成員。
公有方法:
- ArrayList<String> divideMessage (String text)
當短信超過SMS消息的最大長度時,將短信分割為幾塊。
參數:text——初始的消息,不能為空
返回值:有序的ArrayList<String>,可以重新組合為初始的消息
- static SmsManager getDefault ()
獲取SmsManager的默認實例。
返回值:SmsManager的默認實例
- void SendDataMessage (String destinationAddress, String scAddress, short destinationPort, byte[] data,PendingIntent sentIntent, PendingIntent deliveryIntent)
發送一個基于SMS的數據到指定的應用程序端口。
參數:
1)、destinationAddress——消息的目標地址
2)、scAddress——服務中心的地址or為空使用當前默認的SMSC
3)、destinationPort——消息的目標端口號
4)、data——消息的主體,即消息要發送的數據
5)、sentIntent——如果不為空,當消息成功發送或失敗這個PendingIntent就廣播。結果代碼是Activity.RESULT_OK表示成功,或RESULT_ERROR_GENERIC_FAILURE、RESULT_ERROR_RADIO_OFF、RESULT_ERROR_NULL_PDU之一表示錯誤。對應RESULT_ERROR_GENERIC_FAILURE,sentIntent可能包括額外的“錯誤代碼”包含一個無線電廣播技術特定的值,通常只在修復故障時有用。 每一個基于SMS的應用程序控制檢測sentIntent。如果sentIntent是空,調用者將檢測所有未知的應用程序,這將導致在檢測的時候發送較小數量的SMS。
6)、deliveryIntent——如果不為空,當消息成功傳送到接收者這個PendingIntent就廣播。
異常:如果destinationAddress或data是空時,拋出IllegalArgumentException異常。
- void sendMultipartTextMessage (String destinationAddress, String scAddress, ArrayList<String> parts,ArrayList<PendingIntent> sentIntents, ArrayList<PendingIntent> deliverIntents)
發送一個基于SMS的多部分文本,調用者應用已經通過調用 divideMessage (String text)將消息分割成正確的大小。
參數:
1)、destinationAddress——消息的目標地址
2)、scAddress——服務中心的地址or為空使用當前默認的SMSC
3)、parts——有序的ArrayList<String>,可以重新組合為初始的消息
4)、sentIntents——跟 SendDataMessage 方法中一樣,只不過這里的是一組PendingIntent
5)、deliverIntents——跟 SendDataMessage 方法中一樣,只不過這里的是一組PendingIntent
異常:如果destinationAddress或data是空時,拋出IllegalArgumentException異常。
- void sendTextMessage
(String destinationAddress, String scAddress, String text, PendingIntent sentIntent,PendingIntent deliveryIntent)
發送一個基于SMS的文本。參數的意義和異常前面的已存在的一樣,不再累述。
代碼封裝如下
SMSMethod 發送短信的單例
public class SMSMethod {
private static SMSMethod mSMSmsMethod;
/* 自定義ACTION常數,作為廣播的Intent Filter識別常數 */
public static String SMS_SEND_ACTIOIN = "SMS_SEND_ACTIOIN";
public static String SMS_DELIVERED_ACTION = "SMS_DELIVERED_ACTION";
/* 建立兩個mServiceReceiver對象,作為類成員變量 */
private SMSReceiver mSendSMSReceiver, mDeliveredSMSReceiver;
private Context mContext;
private SMSMethod(Context context){
mContext=context;
registerReceiver();
}
public static SMSMethod getInstance(Context context){
if (mSMSmsMethod==null){
synchronized (SMSMethod.class){
if (mSMSmsMethod==null){
mSMSmsMethod=new SMSMethod(context);
}
}
}
return mSMSmsMethod;
}
/**
* 注冊
*/
public void registerReceiver(){
/* 自定義IntentFilter為SENT_SMS_ACTIOIN Receiver */
IntentFilter mFilter01;
mFilter01 = new IntentFilter(SMS_SEND_ACTIOIN);
mSendSMSReceiver = new SMSReceiver();
mContext.registerReceiver(mSendSMSReceiver, mFilter01);
/* 自定義IntentFilter為DELIVERED_SMS_ACTION Receiver */
mFilter01 = new IntentFilter(SMS_DELIVERED_ACTION);
mDeliveredSMSReceiver = new SMSReceiver();
mContext.registerReceiver(mDeliveredSMSReceiver, mFilter01);
}
public void unregisterReceiver(){
/* 取消注冊自定義Receiver */
if (mSendSMSReceiver!=null){
mContext.unregisterReceiver(mSendSMSReceiver);
}
if (mDeliveredSMSReceiver!=null) {
mContext.unregisterReceiver(mDeliveredSMSReceiver);
}
}
public void SendMessage(String strDestAddress,String strMessage){
/* 建立SmsManager對象 */
SmsManager smsManager = SmsManager.getDefault();
try {
/* 建立自定義Action常數的Intent(給PendingIntent參數之用) */
Intent itSend = new Intent(SMS_SEND_ACTIOIN);
Intent itDeliver = new Intent(SMS_DELIVERED_ACTION);
/* sentIntent參數為傳送后接受的廣播信息PendingIntent */
PendingIntent mSendPI = PendingIntent.getBroadcast(mContext, 0, itSend, 0);
/* deliveryIntent參數為送達后接受的廣播信息PendingIntent */
PendingIntent mDeliverPI = PendingIntent.getBroadcast(mContext, 0, itDeliver, 0);
List<String> divideContents = smsManager.divideMessage(strMessage);
for (String text:divideContents) {
/* 發送SMS短信,注意倒數的兩個PendingIntent參數 */
smsManager.sendTextMessage(strDestAddress, null, text, mSendPI, mDeliverPI);
}
}catch(Exception e) {
e.printStackTrace();
}
}
public void SendMessage2(String strDestAddress,String strMessage){
ArrayList<PendingIntent> sentPendingIntents = new ArrayList<PendingIntent>();
ArrayList<PendingIntent> deliveredPendingIntents = new ArrayList<PendingIntent>();
/* 建立SmsManager對象 */
SmsManager smsManager = SmsManager.getDefault();
try {
/* 建立自定義Action常數的Intent(給PendingIntent參數之用) */
Intent itSend = new Intent(SMS_SEND_ACTIOIN);
Intent itDeliver = new Intent(SMS_DELIVERED_ACTION);
/* sentIntent參數為傳送后接受的廣播信息PendingIntent */
PendingIntent mSendPI = PendingIntent.getBroadcast(mContext, 0, itSend, 0);
/* deliveryIntent參數為送達后接受的廣播信息PendingIntent */
PendingIntent mDeliverPI = PendingIntent.getBroadcast(mContext, 0, itDeliver, 0);
ArrayList<String> mSMSMessage = smsManager.divideMessage(strMessage);
for (int i = 0; i < mSMSMessage.size(); i++) {
sentPendingIntents.add(i, mSendPI);
deliveredPendingIntents.add(i, mDeliverPI);
}
/* 發送SMS短信,注意倒數的兩個PendingIntent參數 */
smsManager.sendMultipartTextMessage(strDestAddress,null,mSMSMessage ,sentPendingIntents,deliveredPendingIntents);
}catch(Exception e) {
e.printStackTrace();
}
}
}
短信發送狀態監聽
public class SMSReceiver extends BroadcastReceiver{
@Override
public void onReceive(Context context, Intent intent) {
if (intent.getAction().equals(SMSMethod.SMS_SEND_ACTIOIN)){
try{
/* android.content.BroadcastReceiver.getResultCode()方法 */
//Retrieve the current result code, as set by the previous receiver.
switch (getResultCode()){
case Activity.RESULT_OK:
Toast.makeText(context, "短信發送成功", Toast.LENGTH_SHORT).show();
break;
case SmsManager.RESULT_ERROR_GENERIC_FAILURE:
Toast.makeText(context, "短信發送失敗", Toast.LENGTH_SHORT).show();
break;
case SmsManager.RESULT_ERROR_RADIO_OFF:
break;
case SmsManager.RESULT_ERROR_NULL_PDU:
break;
}
}catch (Exception e){
}
} else if(intent.getAction().equals(SMSMethod.SMS_DELIVERED_ACTION)){
/* android.content.BroadcastReceiver.getResultCode()方法 */
switch(getResultCode()){
case Activity.RESULT_OK:
Toast.makeText(context, "短信已送達", Toast.LENGTH_SHORT).show();
break;
case SmsManager.RESULT_ERROR_GENERIC_FAILURE:
/* 短信未送達 */
Toast.makeText(context, "短信未送達", Toast.LENGTH_SHORT).show();
break;
case SmsManager.RESULT_ERROR_RADIO_OFF:
break;
case SmsManager.RESULT_ERROR_NULL_PDU:
break;
}
}
}
}
在AndroidManifest.xml中添加監聽
<!-- 短信發送送達--><receiver android:name=".sms.SMSReceiver"/>
-
一些例子
public void sendTextMessage(View view){
SMSMethod.getInstance(this).SendMessage("這里填寫手機號碼","測試短信.....Javen");
}
public void sendMultipartTextMessage(View view){
SMSMethod.getInstance(this).SendMessage2("這里填寫手機號碼", "測試短信......Javen");
}
@Override
protected void onPause() {
SMSMethod.getInstance(this).unregisterReceiver();
super.onPause();
}
來自:http://www.androidchina.net/5575.html