1、布局文件:

activity_sms.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"android:layout_width="match_parent"android:layout_height="match_parent"android:orientation="vertical" ><TextView
        android:id="@+id/tv_input_number"android:layout_width="wrap_content"android:layout_height="wrap_content"android:text="@string/pleaseInputNumber" /><EditText
        android:id="@+id/et_number"android:layout_width="match_parent"android:layout_height="wrap_content"android:ems="10"android:singleLine="true"android:inputType="phone" ><!-- 下面的这个标签是用来当手机运行时,当这个EditText获得焦点之后,就会弹出一个软键盘,但在模拟器中没有,因此不需要 --><!-- <requestFocus />--></EditText><TextView
        android:id="@+id/tv_content"android:layout_width="wrap_content"android:layout_height="wrap_content"android:text="@string/pleaseInputContent" /><EditText
        android:id="@+id/et_content"android:layout_width="match_parent"android:layout_height="wrap_content"android:lines="10"android:ems="10" />
<!-- android:ems用来设置EditText或TextView显示的字符宽度。例如android:ems="10"标识显示10个字符,多余的不显示 --><Button
        android:id="@+id/btn_send"android:layout_width="wrap_content"android:layout_height="wrap_content"android:text="@string/fasong" />
</LinearLayout>

2、Java文件

SmsActivity.java

public class SmsActivity extends Activity implements OnClickListener{   private EditText mEditTextNumber;private EditText mEditTextContent;@Overrideprotected void onCreate(Bundle savedInstanceState) {// TODO Auto-generated method stubsuper.onCreate(savedInstanceState);setContentView(R.layout.activity_sms);Button btn_send = (Button)this.findViewById(R.id.btn_send);mEditTextNumber = (EditText)this.findViewById(R.id.et_number);mEditTextContent = (EditText)this.findViewById(R.id.et_content);            }@Overridepublic void onClick(View v) {switch (v.getId()) {case R.id.btn_send://获得短信发送管理器的一个实例,一般的情况下,如果一个类没有提供构造方法的话,都会有一个getDefault或者getInstance方法//来获得这个类的实例SmsManager sManager = SmsManager.getDefault();String number = mEditTextNumber.getText().toString().trim();String content= mEditTextContent.getText().toString();if(TextUtils.isEmpty(number) || TextUtils.isEmpty(content)){Toast.makeText(this, "请输入电话或者短信内容", Toast.LENGTH_SHORT).show();return;}//这样就可以完成一条短信的发送,但由于短信长度的限制:中文70个汉字,英文160个字符//为了防止出现这种情况,将一条短信短信分成小于短信长度List<String> contents = sManager.divideMessage(content);for(String sms:contents){sManager.sendTextMessage(number, null, sms, null, null);}                       break;default:break;}}
}

3、在AndroidManifest.xml文件中添加发送短信的权限

<uses-permission android:name="android.permission.SEND_SMS"/> 

4、说明:

核心代码:
(1)SmsManager manager = SmsManager.getDefault(); //获得默认的消息管理器
(2)ArrayList list = manager.divideMessage(String txt); //拆分长短信
(3)manager.sendTextMessage(String phone,null,String content,null,null); //发送短信

注意:这里是使用系统的短信管理器来发送的短信,在发送端的并不会显示发送的记录,这也就类似于一种黑客短信一样。

5、运行结果:


6、扩展阅读:

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<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 Receiversthis.registerReceiver(new BroadcastReceiver() {@Overridepublic 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 parameterIntent deliverIntent = new Intent(DELIVERED_SMS_ACTION);deliverPI = PendingIntent.getBroadcast(this, 0,deliverIntent, 0);this.registerReceiver(new BroadcastReceiver() {@Overridepublic void onReceive(Context _context, Intent _intent) {Toast.makeText(MainActivity.this,"收信人已经成功接收", Toast.LENGTH_SHORT).show();}}, new IntentFilter(DELIVERED_SMS_ACTION));

以下是对以上代码的封装:

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

第三、短信发送状态的监听

import android.app.Activity;
import android.content.BroadcastReceiver;
import android.content.Context;
import android.content.Intent;
import android.telephony.SmsManager;
import android.widget.Toast; public class SMSReceiver extends BroadcastReceiver{@Overridepublic 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。。。");} @Overrideprotected void onPause() {SMSMethod.getInstance(this).unregisterReceiver();super.onPause();}

别忘了权限的问题:

<uses-permission android:name="android.permission.SEND_SMS" /> 

Android短信发送相关推荐

  1. android短信功能裁剪,Android短信发送功能实现技巧分享

    如现在启动一模拟器id 号为5554,运行cmd telnet localhost 5554 输入help 可以看到很多用于模拟器中的功能命令 gsm call 134343434   // 便是呼叫 ...

  2. Android短信发送流程之多收件人发送(原)

    前面的< Android短信发送流程之长短信发送 >中介绍了长短信对于普通短信的区别,而对于多收件人的情况,在SmsMessageSender的queueMessage()方法中我们了解到 ...

  3. Android短信发送流程之长短信发送(原)

    从前面< Android短信发送流程之普通短信发送 >流程看到,长短信与普通短信的流程从SmsManager的sendMultipartTextMessage()方法开始区分,现在我们来看 ...

  4. Android短信发送流程之普通短信发送(原)

    我们先来看最简单的流程入手分析,即收件人只有一个,而且不是长短信的情况. 一.地址有效性检测 当点击发送按钮时,触发onClick事件: [java] view plaincopy @ComposeM ...

  5. android短信发送和接受

    短信发送 发短信第一件事是在manifest文件中添加权限 <uses-permission android:name="android.permission.SEND_SMS&quo ...

  6. Android 短信发送失败是如何监听到的

    之前做项目,遇到需求:在短信发送失败后,弹出对话框,提示失败,如果用户点击retry,则开始重新发送,否则什么都不干. 高通8.0短信发送失败处理: 平台发送短信后会监听短信是否发送成功,这里主要看失 ...

  7. android 数据存储----android短信发送器之文件的读写(手机+SD卡)

    本文实践知识点有有三: 1.布局文件,android布局有相对布局,线性布局,绝对布局,表格布局,标签布局等.各个布局能够嵌套的.本文的布局文件就是线性布局的嵌套 <LinearLayout x ...

  8. android短信发送流程,Android 发送短信程序

    [android]代码库mButton1.setOnClickListener(new Button.OnClickListener() { @Override public void onClick ...

  9. android短信发送乱码,解决CEMAPI发送中文短信时会乱码

    作者:陈缘 联系:luandao2000@gmail.com 博客:http://blog.csdn.net/luandao2000 主页:http://www.spbase.com 这个问题 所有用 ...

最新文章

  1. winrar压缩文件但是排除指定目录
  2. 图灵机原理三体中人计算机,有关计算机中人列计算机的问题
  3. Debian7 apt源设置
  4. net程序员的iPhone开发-MonoTouch
  5. 【狂转】某个N人的访谈记录
  6. (转)用DynamicMethod提升ORM系统转换业务数据的性能
  7. centos安装下载桌面
  8. antd vue form表单 子组件调用父组件的方法没反应_前几天推了Vue,今天给React疯狂打call...
  9. spring cloud微服务之间调用Feign
  10. JDK 和 tomcat 安装 配置
  11. 【服务器代理跨域】---测试网络上一些接口是否可以被调用
  12. ux.plup.File plupload 集成 ux.plup.FileLis 批量上传预览
  13. Yanobox Moods for mac(FCPX/AE/PR滤镜插件)激活版
  14. 云:SD-WAN不断增长的驱动力
  15. 高中学计算机都是学什么,学计算机高中选什么科目
  16. Ubuntu 10.10 无线网络已经禁用” “wiress is disabled” 解决方法
  17. 升哲科技荣获2022年度华夏建设科学技术奖二等奖
  18. 001 JAVA知识体系
  19. 【零基础学STM32】CubeMX+HAL 喂狗小教程
  20. 教学计算机水平材料,有关计算机基础教学计划材料

热门文章

  1. FPGA高速数据采集设计JESD204B接口
  2. GNSS-INS组合导航:KF-GINS(四)
  3. 2021 中国软件 100 强,腾讯第二、百度第三,第一竟然是他!
  4. 湖南2018年通信工程师现场审核时间|地点|材料
  5. 浅谈微信抢房中的软件操作逻辑
  6. CNAS实验室申请流程之二
  7. String你真的会吗?不会还不进来!!!是等我胖虎锤各位呢?!!!
  8. 测试胖虎原来在教你,如何使用技术代码情人节在线撩妹520
  9. android获取网络时区_android 网络获取当前时区
  10. 无中频软件无线电芯片AD9361的基本介绍