热门标签 | HotTags
当前位置:  开发笔记 > Android > 正文

Android发送短信方法总结

这篇文章主要介绍了Android发送短信方法,结合实例形式较为详细的分析了Android发送短信的原理与具体实现技巧,需要的朋友可以参考下

android API 中提供了SmsManager类处理短信。其中的sendTextMessage(num, null, content, pend, null)函数就是发送,具体介绍如下:

SMS涉及的主要类SmsManager

实现SMS主要用到SmsManager类,该类继承自java.lang.Object类,下面我们介绍一下该类的主要成员。
公有方法:

1、ArrayList divideMessage(String text)

当短信超过SMS消息的最大长度时,将短信分割为几块。
参数:text——初始的消息,不能为空
返回值:有序的ArrayList,可以重新组合为初始的消息

2、static SmsManager getDefault()

获取SmsManager的默认实例。
返回值:SmsManager的默认实例

3、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异常。

4、void sendMultipartTextMessage(String destinationAddress, String scAddress, ArrayList parts,ArrayList sentIntents, ArrayList  deliverIntents)

发送一个基于SMS的多部分文本,调用者应用已经通过调用divideMessage(String text)将消息分割成正确的大小。

参数:

1)、destinationAddress——消息的目标地址

2)、scAddress——服务中心的地址or为空使用当前默认的SMSC

3)、parts——有序的ArrayList,可以重新组合为初始的消息

4)、sentIntents——跟SendDataMessage方法中一样,只不过这里的是一组PendingIntent

5)、deliverIntents——跟SendDataMessage方法中一样,只不过这里的是一组PendingIntent
异常:如果destinationAddress或data是空时,抛出IllegalArgumentException异常。

5、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 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 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 sentPendingIntents = new ArrayList();
    ArrayList deliveredPendingIntents = new ArrayList();


    /* 建立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 mSMSMessage = smsManager.divideMessage(strMessage);

      for (int i = 0; i 

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;
      }
    }
  }
}

测试代码:

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();
  }

别忘了权限的问题:

 

 以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。


推荐阅读
  • 本文介绍如何在 Android 中通过代码模拟用户的点击和滑动操作,包括参数说明、事件生成及处理逻辑。详细解析了视图(View)对象、坐标偏移量以及不同类型的滑动方式。 ... [详细]
  • 深入理解OAuth认证机制
    本文介绍了OAuth认证协议的核心概念及其工作原理。OAuth是一种开放标准,旨在为第三方应用提供安全的用户资源访问授权,同时确保用户的账户信息(如用户名和密码)不会暴露给第三方。 ... [详细]
  • 本文总结了2018年的关键成就,包括职业变动、购车、考取驾照等重要事件,并分享了读书、工作、家庭和朋友方面的感悟。同时,展望2019年,制定了健康、软实力提升和技术学习的具体目标。 ... [详细]
  • 在计算机技术的学习道路上,51CTO学院以其专业性和专注度给我留下了深刻印象。从2012年接触计算机到2014年开始系统学习网络技术和安全领域,51CTO学院始终是我信赖的学习平台。 ... [详细]
  • CSS 布局:液态三栏混合宽度布局
    本文介绍了如何使用 CSS 实现液态的三栏布局,其中各栏具有不同的宽度设置。通过调整容器和内容区域的属性,可以实现灵活且响应式的网页设计。 ... [详细]
  • Linux 系统启动故障排除指南:MBR 和 GRUB 问题
    本文详细介绍了 Linux 系统启动过程中常见的 MBR 扇区和 GRUB 引导程序故障及其解决方案,涵盖从备份、模拟故障到恢复的具体步骤。 ... [详细]
  • 本文介绍了如何使用jQuery根据元素的类型(如复选框)和标签名(如段落)来获取DOM对象。这有助于更高效地操作网页中的特定元素。 ... [详细]
  • 本文将详细介绍如何使用剪映应用中的镜像功能,帮助用户轻松实现视频的镜像效果。通过简单的步骤,您可以快速掌握这一实用技巧。 ... [详细]
  • 深入理解Cookie与Session会话管理
    本文详细介绍了如何通过HTTP响应和请求处理浏览器的Cookie信息,以及如何创建、设置和管理Cookie。同时探讨了会话跟踪技术中的Session机制,解释其原理及应用场景。 ... [详细]
  • 本文介绍如何在 Xcode 中使用快捷键和菜单命令对多行代码进行缩进,包括右缩进和左缩进的具体操作方法。 ... [详细]
  • 本文介绍了一款用于自动化部署 Linux 服务的 Bash 脚本。该脚本不仅涵盖了基本的文件复制和目录创建,还处理了系统服务的配置和启动,确保在多种 Linux 发行版上都能顺利运行。 ... [详细]
  • 在Linux系统中配置并启动ActiveMQ
    本文详细介绍了如何在Linux环境中安装和配置ActiveMQ,包括端口开放及防火墙设置。通过本文,您可以掌握完整的ActiveMQ部署流程,确保其在网络环境中正常运行。 ... [详细]
  • Android 渐变圆环加载控件实现
    本文介绍了如何在 Android 中创建一个自定义的渐变圆环加载控件,该控件已在多个知名应用中使用。我们将详细探讨其工作原理和实现方法。 ... [详细]
  • 如何在WPS Office for Mac中调整Word文档的文字排列方向
    本文将详细介绍如何使用最新版WPS Office for Mac调整Word文档中的文字排列方向。通过这些步骤,用户可以轻松更改文本的水平或垂直排列方式,以满足不同的排版需求。 ... [详细]
  • 本文总结了在使用Ionic 5进行Android平台APK打包时遇到的问题,特别是针对QRScanner插件的改造。通过详细分析和提供具体的解决方法,帮助开发者顺利打包并优化应用性能。 ... [详细]
author-avatar
轩楼妈
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有