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的文本。参数的意义和异常前面的已存在的一样,不再累述。

常量:

    • public static final int RESULT_ERROR_GENERIC_FAILURE 
      表示普通错误,值为1(0x00000001)
    • public static final int RESULT_ERROR_NO_SERVICE 
      表示服务当前不可用,值为4 (0x00000004)
    • public static final int RESULT_ERROR_NULL_PDU 
      表示没有提供pdu,值为3 (0x00000003)
    • public static final int RESULT_ERROR_RADIO_OFF 
      表示无线广播被明确地关闭,值为2 (0x00000002)
    • public static final int STATUS_ON_ICC_FREE 
      表示自由空间,值为0 (0x00000000)
    • public static final int STATUS_ON_ICC_READ 
      表示接收且已读,值为1 (0x00000001)
    • public static final int STATUS_ON_ICC_SENT 
      表示存储且已发送,值为5 (0x00000005)
    • public static final int STATUS_ON_ICC_UNREAD 
      表示接收但未读,值为3 (0x00000003)
    • public static final int STATUS_ON_ICC_UNSENT 
      表示存储但为发送,值为7 (0x00000007)

第一:调用系统短信接口直接发送短信;主要代码如下: 

/**
* 直接调用短信接口发短信
*
* @param phoneNumber
* @param message
*/
public void sendSMS(String phoneNumber, String message) {
// 获取短信管理器
android.telephony.SmsManager smsManager = android.telephony.SmsManager
.getDefault();
// 拆分短信内容(手机短信长度限制)
List<String> divideContents = smsManager.divideMessage(message);
for (String text : divideContents) {
smsManager.sendTextMessage(phoneNumber, null, text, sentPI,
deliverPI);
}
}

第二:调起系统发短信功能;主要代码如下: 

/**
* 调起系统发短信功能
* @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);
}
}

下面来主要讲解第一种方法,第一种方法可以监控发送状态和对方接收状态使用的比较多。

处理返回的状态代码如下:

  

//处理返回的发送状态
String SENT_SMS_ACTION = "SENT_SMS_ACTION";
Intent sentIntent = new Intent(SENT_SMS_ACTION);
sentPI= PendingIntent.getBroadcast(this, 0, sentIntent,
0);
// register the Broadcast Receivers
this.registerReceiver(new BroadcastReceiver() {
@Override
public void onReceive(Context _context, Intent _intent) {
switch (getResultCode()) {
case Activity.RESULT_OK:
Toast.makeText(MainActivity.this,
"短信发送成功", Toast.LENGTH_SHORT)
.show();
break;
case SmsManager.RESULT_ERROR_GENERIC_FAILURE:
break;
case SmsManager.RESULT_ERROR_RADIO_OFF:
break;
case SmsManager.RESULT_ERROR_NULL_PDU:
break;
}
}
}, new IntentFilter(SENT_SMS_ACTION)); //处理返回的接收状态
String DELIVERED_SMS_ACTION = "DELIVERED_SMS_ACTION";
// create the deilverIntent parameter
Intent deliverIntent = new Intent(DELIVERED_SMS_ACTION);
deliverPI = PendingIntent.getBroadcast(this, 0,
deliverIntent, 0);
this.registerReceiver(new BroadcastReceiver() {
@Override
public void onReceive(Context _context, Intent _intent) {
Toast.makeText(MainActivity.this,
"收信人已经成功接收", Toast.LENGTH_SHORT)
.show();
}
}, new IntentFilter(DELIVERED_SMS_ACTION));

以下是对以上代码的封装

1、短信的发送

import android.app.PendingIntent;
import android.content.Context;
import android.content.Intent;
import android.content.IntentFilter;
import android.telephony.SmsManager; import java.util.ArrayList;
import java.util.List; /**
* Created by Javen on 2016-03-15.
*/
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();
}
}
}

2、短信发送状态的监听

package com.javen.sms.receiver;

import android.app.Activity;
import android.content.BroadcastReceiver;
import android.content.Context;
import android.content.Intent;
import android.telephony.SmsManager;
import android.widget.Toast; /**
* Created by Javen on 2016-03-15.
*/
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:
System.out.println("短信发送成功");
Toast.makeText(context, "短信发送成功", Toast.LENGTH_SHORT).show();
break;
case SmsManager.RESULT_ERROR_GENERIC_FAILURE:
System.out.println("短信发送失败");
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){
e.printStackTrace();
}
} else if(intent.getAction().equals(SMSMethod.SMS_DELIVERED_ACTION)){
/* android.content.BroadcastReceiver.getResultCode()方法 */
switch(getResultCode()){
case Activity.RESULT_OK:
System.out.println("短信已送达");
Toast.makeText(context, "短信已送达", Toast.LENGTH_SHORT).show();
break;
case SmsManager.RESULT_ERROR_GENERIC_FAILURE:
System.out.println("短信未送达");
/* 短信未送达 */
Toast.makeText(context, "短信未送达", Toast.LENGTH_SHORT).show();
break;
case SmsManager.RESULT_ERROR_RADIO_OFF:
break;
case SmsManager.RESULT_ERROR_NULL_PDU:
break;
}
}
}
}
  <!-- 短信发送送达-->
<receiver android:name="com.javen.sms.receiver.SMSReceiver"/>

测试代码:

public void sendTextMessage(View view){
SMSMethod.getInstance(this).SendMessage("xxxx","测试短信。。。");
}
public void sendMultipartTextMessage(View view){
SMSMethod.getInstance(this).SendMessage2("xxxx", "测试短信wwww。。。测试短信wwww。。。测试短信wwww。。。测试短信wwww。。。测试短信wwww。。。测试短信wwww。。。测试短信wwww。。。测试短信wwww。。。测试短信wwww。。。测试短信wwww。。。测试短信wwww。。。测试短信wwww。。。测试短信wwww。。。测试短信wwww。。。测试短信wwww。。。测试短信wwww。。。测试短信wwww。。。测试短信wwww。。。测试短信wwww。。。测试短信wwww。。。测试短信wwww。。。测试短信wwww。。。测试短信wwww。。。测试短信wwww。。。测试短信wwww。。。测试短信wwww。。。测试短信wwww。。。测试短信wwww。。。测试短信wwww。。。测试短信wwww。。。测试短信wwww。。。测试短信wwww。。。测试短信wwww。。。测试短信wwww。。。测试短信wwww。。。测试短信wwww。。。");
} @Override
protected void onPause() {
SMSMethod.getInstance(this).unregisterReceiver();
super.onPause();
}

别忘了权限的问题: 
<uses-permission android:name="android.permission.SEND_SMS" />

源码下载地址:http://download.csdn.net/detail/zyw_java/8917057

Android 发送短信总结的更多相关文章

  1. android 发送短信 怎样做到一条一条的发送,仅仅有在上一条发送成功之后才发送下一条短信

    android发送短信截获上一条发送是否成功,然后再来发送下一条短信 1.问题:在项目中遇到例如以下要求:待发短信有N条,实现一条一条的发送并在上一条短信发送成功之后再来发送下一条. for(int ...

  2. android 发送短信的两种方式,以及接收报告和发送报告

               android发送短信,以及接收报告和发送报告          android中发送短信其实有两种方式,这个和打电话类似,大家可以了解一下:    一.调起系统发短信功能    ...

  3. android发送短信验证码并自动获取验证码填充文本框

    android注册发送短信验证码并自动获取短信,截取数字验证码填充文本框. 一.接入短信平台 首先需要选择短信平台接入,这里使用的是榛子云短信平台(http://smsow.zhenzikj.com) ...

  4. android发送短信样例

    Android应用开发中我们经常须要发送手机短信.这对于android平台来说,是最简单只是的功能了,无需太多代码,也无需自己定义代码,仅仅须要调用android提供的消息管理类SmsManager就 ...

  5. 【Android】Android 发送短信和打电话的方法

    发送短信的方法 有两种方法可以实现发送短信,其一是使用intent-startActivity,URI数据格式为"smsto:num",调用的action为Intent.ACTIO ...

  6. 关于Android发送短信获取送达报告的问题

    最近公司开发一个项目,要求app能够发送短信并获取送达报告.这本不是一个什么难题,实现这一功能的代码一搜一大把,那么这么简单的一个问题,为什么我要在这里提出来呢?那是因为我在写代码的时候掉入了一个坑, ...

  7. Android发送短信核心代码

    核心代码:(1)SmsManager manager = SmsManager.getDefault(); //获得默认的消息管理器(2)ArrayList<String> list = ...

  8. Android发送短信

    // 发送短信 public void sendMsg(){ String content = edtSend.getText().toString(); SmsManager smsManager ...

  9. android发送短信代码(短信内容超长处理)

    一条短信只可容纳70个中文,所以当短信长度超过70个中文字符时程序就要特殊处理了. 有两种方式: 1.通过sendTextMessage()方法依次发送拆分后的短信,该方式有个弊端就是用户会分条收到短 ...

随机推荐

  1. 安装jdk8-linux版

    下载jdk http://www.oracle.com/technetwork/java/javase/downloads/jdk8-downloads-2133151.html 安装 rpm -iv ...

  2. Nginx+PHP “No input file specified”错误的解决办法

    配置官网商城php网站时候,界面报错“No input file specified” 原理: 任何对.php文件的请求,都简单地交给php-cgi去处理,但没有验证该php文件是否存在. PHP文件 ...

  3. Oracle基础了解

    数据库: 关系型数据库 select * from 表名 非关系型数据库(做不到复杂查询) 以对象的形式进行存储 {"aaa":"ccc"}---键值对 ora ...

  4. 原型开发工具 mockplus

    韩梦飞沙  韩亚飞  313134555@qq.com  yue31313  han_meng_fei_sha 原型开发工具  mockplus 微信(演示) - Mockup Plus Web Ap ...

  5. VB查询数据库之结账——机房收费系统总结(五)

    对于机房收费的结账,我感觉是所有窗体中,最难的一个.这个窗体我真的做了好多天.它的难度系数我感觉是最高的. 首先,你要理清上机时间和收费标准的关系,在预备时间中,是不收费的. 其次,在超过预备时间,一 ...

  6. 【BZOJ 4104】【THUSC 2015】解密运算

    http://www.lydsy.com/JudgeOnline/problem.php?id=4104 网上题解满天飞,我也懒得写了 #include<cstdio> #include& ...

  7. 关于网络流sap算法

    今天终于学习了网络流..之前一直很怕这类问题,个人觉得网络流算是图论里面最难的了.... sap学习下来感觉一般,关于解法都是意识流,细节也是蛮多的.. 我这里先贴一份模版,自已也加了点注释(只是个人 ...

  8. python基础之re,sys,suprocess模块

    re 正则表达式 1.什么是正则? 正则就是用一系列具有特殊含义的字符组成的规则,该规则用来描述具有某一特征的字符串. 正则就是用来在一个大的字符串匹配出符合规则的子字符串 2.为什么用正则? 正则可 ...

  9. 解决maven无法下载jar的问题

    先去本地仓库查看是否有没有jar包,如果没有并且存在除jar包以外的文件,先将文件删除,重新用maven下载一遍.如果还是不行,就自己下载jar包导入到本地仓库,但是不能手动的添加文件夹和pom.xm ...

  10. Problem D: 统计元音字母数

    #include<stdio.h> int main() { ]; int n,j,k,a,e,i,o,u; a=e=i=o=u=; gets(c); ;c[k]!='\0';k++) { ...