Android发送短信


在Android中,您可以使用SmsManager API或设备内置SMS应用程序来发送SMS。在本教程中,我们向您展示了发送SMS消息的两个基本示例 -

SmsManager API

SmsManager smsManager = SmsManager.getDefault();
smsManager.sendTextMessage("phoneNo", null, "sms message", null, null);

内置SMS应用程序

Intent sendIntent = new Intent(Intent.ACTION_VIEW);
sendIntent.putExtra("sms_body", "default content");
sendIntent.setType("vnd.android-dir/mms-sms");
startActivity(sendIntent);

当然,两者都需要 SEND_SMS权限

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

除了上述方法之外,SmsManager类中还有其他一些重要的功能。这些方法如下

序号 方法和描述
1

ArrayList <String> divideMessage(String text)

此方法将消息文本划分为多个片段,均不大于最大SMS消息大小。

2

static SmsManager getDefault()

此方法用于获取SmsManager的默认实例

3

void sendDataMessage(String destinationAddress,String scAddress,short destinationPort,byte [] data,PendingIntent sentIntent,PendingIntent deliveryIntent)

此方法用于将基于数据的SMS发送到特定应用程序端口。

4

void sendMultipartTextMessage(String destinationAddress,String scAddress,ArrayList <String> parts,ArrayList <PendingIntent> sentIntents,ArrayList <PendingIntent> deliveryIntents)

发送基于多部分文本的SMS。

5

void sendTextMessage(String destinationAddress,String scAddress,String text,PendingIntent sentIntent,PendingIntent deliveryIntent)

发送基于短信的文本。

下面的示例向您展示了如何使用SmsManager对象将SMS发送到给定的手机号码。

要试验这个例子,您需要配备最新Android操作系统的实际移动设备,否则您将不得不与可能无法运行的模拟器斗争。

描述
1 您将使用Android Studio IDE创建Android应用程序,并com.example.codingdict包下将其命名为codingdict
2 修改src / MainActivity.java文件并添加所需的代码以处理发送短信。
3 修改布局XML文件res / layout / activity_main.xml根据需要添加任何GUI组件。我正在添加一个简单的GUI来发送手机号码和SMS文本以及一个发送短信的简单按钮。
4 无需在res / values / strings.xml中定义默认字符串常量。Android studio负责默认常量。
5 修改AndroidManifest.xml,如下所示
6 运行应用程序以启动Android模拟器并验证应用程序中所做更改的结果。

以下是修改后的主活动文件 src / com.example.codingdict / MainActivity.java 的内容 。

package com.example.codingdict;

import android.Manifest;
import android.content.pm.PackageManager;
import android.os.Bundle;
import android.app.Activity;

import android.support.v4.app.ActivityCompat;
import android.support.v4.content.ContextCompat;
import android.telephony.SmsManager;

import android.util.Log;
import android.view.Menu;
import android.view.View;

import android.widget.Button;
import android.widget.EditText;
import android.widget.Toast;

public class MainActivity extends Activity {
   private static final int MY_PERMISSIONS_REQUEST_SEND_SMS =0 ;
   Button sendBtn;
   EditText txtphoneNo;
   EditText txtMessage;
   String phoneNo;
   String message;

   @Override
   protected void onCreate(Bundle savedInstanceState) {
      super.onCreate(savedInstanceState);
      setContentView(R.layout.activity_main);

      sendBtn = (Button) findViewById(R.id.btnSendSMS);
      txtphoneNo = (EditText) findViewById(R.id.editText);
      txtMessage = (EditText) findViewById(R.id.editText2);

      sendBtn.setOnClickListener(new View.OnClickListener() {
         public void onClick(View view) {
            sendSMSMessage();
         }
      });
   }

   protected void sendSMSMessage() {
      phoneNo = txtphoneNo.getText().toString();
      message = txtMessage.getText().toString();

      if (ContextCompat.checkSelfPermission(this,
         Manifest.permission.SEND_SMS)
         != PackageManager.PERMISSION_GRANTED) {
            if (ActivityCompat.shouldShowRequestPermissionRationale(this,
               Manifest.permission.SEND_SMS)) {
            } else {
               ActivityCompat.requestPermissions(this,
                  new String[]{Manifest.permission.SEND_SMS},
                  MY_PERMISSIONS_REQUEST_SEND_SMS);
            }
      }
   }

   @Override
   public void onRequestPermissionsResult(int requestCode,String permissions[], int[] grantResults) {
      switch (requestCode) {
         case MY_PERMISSIONS_REQUEST_SEND_SMS: {
            if (grantResults.length > 0
               && grantResults[0] == PackageManager.PERMISSION_GRANTED) {
                  SmsManager smsManager = SmsManager.getDefault();
                  smsManager.sendTextMessage(phoneNo, null, message, null, null);
                  Toast.makeText(getApplicationContext(), "SMS sent.",
                     Toast.LENGTH_LONG).show();
            } else {
               Toast.makeText(getApplicationContext(),
                  "SMS faild, please try again.", Toast.LENGTH_LONG).show();
               return;
            }
         }
      }

   }
}

以下是 res / layout / activity_main.xml 文件的内容 -

这里abc表示codingdict徽标

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
   xmlns:tools="http://schemas.android.com/tools"
   android:layout_width="match_parent"
   android:layout_height="match_parent"
   android:paddingBottom="@dimen/activity_vertical_margin"
   android:paddingLeft="@dimen/activity_horizontal_margin"
   android:paddingRight="@dimen/activity_horizontal_margin"
   android:paddingTop="@dimen/activity_vertical_margin"
   tools:context="MainActivity">

   <TextView
      android:id="@+id/textView1"
      android:layout_width="wrap_content"
      android:layout_height="wrap_content"
      android:text="Sending SMS Example"
      android:layout_alignParentTop="true"
      android:layout_centerHorizontal="true"
      android:textSize="30dp" />

   <TextView
      android:id="@+id/textView2"
      android:layout_width="wrap_content"
      android:layout_height="wrap_content"
      android:text="Tutorials point "
      android:textColor="#ff87ff09"
      android:textSize="30dp"
      android:layout_below="@+id/textView1"
      android:layout_alignRight="@+id/imageButton"
      android:layout_alignEnd="@+id/imageButton" />

   <ImageButton
      android:layout_width="wrap_content"
      android:layout_height="wrap_content"
      android:id="@+id/imageButton"
      android:src="@drawable/abc"
      android:layout_below="@+id/textView2"
      android:layout_centerHorizontal="true" />

   <EditText
      android:layout_width="wrap_content"
      android:layout_height="wrap_content"
      android:id="@+id/editText"
      android:hint="Enter Phone Number"
      android:phoneNumber="true"
      android:textColorHint="@color/abc_primary_text_material_dark"
      android:layout_below="@+id/imageButton"
      android:layout_centerHorizontal="true" />

   <EditText
      android:layout_width="wrap_content"
      android:layout_height="wrap_content"
      android:id="@+id/editText2"
      android:layout_below="@+id/editText"
      android:layout_alignLeft="@+id/editText"
      android:layout_alignStart="@+id/editText"
      android:textColorHint="@color/abc_primary_text_material_dark"
      android:layout_alignRight="@+id/imageButton"
      android:layout_alignEnd="@+id/imageButton"
      android:hint="Enter SMS" />

   <Button
      android:layout_width="wrap_content"
      android:layout_height="wrap_content"
      android:text="Send Sms"
      android:id="@+id/btnSendSMS"
      android:layout_below="@+id/editText2"
      android:layout_centerHorizontal="true"
      android:layout_marginTop="48dp" />

</RelativeLayout>

以下是 res / values / strings.xml 的内容,用于定义两个新常量 -

<?xml version="1.0" encoding="utf-8"?>
<resources>
   <string name="app_name">codingdict</string>
</resources>

以下是 AndroidManifest.xml 的默认内容 -

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
   package="com.example.codingdict" >

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

   <application
      android:allowBackup="true"
      android:icon="@drawable/ic_launcher"
      android:label="@string/app_name"
      android:theme="@style/AppTheme" >

      <activity
         android:name="com.example.codingdict.MainActivity"
         android:label="@string/app_name" >

         <intent-filter>
            <action android:name="android.intent.action.MAIN" />
            <category android:name="android.intent.category.LAUNCHER" />
         </intent-filter>

      </activity>

   </application>
</manifest>

让我们尝试运行您的 codingdict 应用程序。我假设您已将实际的Android移动设备与计算机相关联。要从Android工作室运行应用程序,请打开项目的某个活动文件,然后单击Eclipse运行图标工具栏中的“运行”图标。在开始应用程序之前,Android studio安装程序将显示以下窗口,以选择要运行Android应用程序的选项。

Android移动设备

现在,您可以输入所需的手机号码和要在该号码上发送的短信。最后点击 发送短信 按钮发送短信。确保您的GSM / CDMA连接正常工作,以便将SMS发送给收件人。

你可以用逗号分隔一些短信,然后在你的程序中你必须将它们解析成一个数组字符串,最后你可以使用一个循环向所有给定的数字发送消息。这就是你如何编写自己的短信客户端。下一节将向您展示如何使用现有的SMS客户端发送SMS。

使用内置Intent发送短信

您可以使用Android Intent通过调用Android的内置SMS功能来发送SMS。以下部分介绍了发送SMS所需的Intent对象的不同部分。

意图对象 - 发送短信的动作

您将使用 ACTION_VIEW 操作启动安装在Android设备上的SMS客户端。以下是使用ACTION_VIEW操作创建意图的简单语法。

Intent smsIntent = new Intent(Intent.ACTION_VIEW);

意图对象 - 要发送SMS的数据/类型

要发送SMS,您需要指定 smsto: 使用setData()方法作为URI,使用setType()方法将数据类型指向 vnd.android- dir / mms-sms ,如下所示 -

smsIntent.setData(Uri.parse("smsto:"));
smsIntent.setType("vnd.android-dir/mms-sms");

意图对象 - 额外发送短信

Android内置支持添加电话号码和短信发送短信如下 -

smsIntent.putExtra("address"  , new String("0123456789;3393993300"));
smsIntent.putExtra("sms_body"  , "Test SMS to Angilla");

这里address和sms_body区分大小写,应该只用小字符指定。您可以在单个字符串中指定多个数字,但用分号(;)分隔。

下面的示例向您展示了如何使用Intent对象启动SMS客户端以向给定的收件人发送SMS。

要试验这个例子,您需要配备最新Android操作系统的实际移动设备,否则您将不得不与可能无法运行的模拟器斗争。

描述
1 您将使用Android studio IDE创建一个Android应用程序,并com.example.codingdict包下将其命名为codingdict
2 修改src / MainActivity.java文件并添加所需的代码以处理发送SMS。
3 修改布局XML文件res / layout / activity_main.xml根据需要添加任何GUI组件。我正在添加一个简单的按钮来启动SMS客户端。
4 无需定义默认常量.Android studio负责默认常量。
5 修改AndroidManifest.xml,如下所示
6 运行应用程序以启动Android模拟器并验证应用程序中所做更改的结果。

以下是修改后的主活动文件 src / com.example.codingdict / MainActivity.java 的内容 。

package com.example.codingdict;

import android.net.Uri;
import android.os.Bundle;
import android.app.Activity;
import android.content.Intent;
import android.util.Log;
import android.view.Menu;
import android.view.View;
import android.widget.Button;
import android.widget.Toast;

public class MainActivity extends Activity {
   @Override
   protected void onCreate(Bundle savedInstanceState) {
      super.onCreate(savedInstanceState);
      setContentView(R.layout.activity_main);

      Button startBtn = (Button) findViewById(R.id.button);
      startBtn.setOnClickListener(new View.OnClickListener() {
         public void onClick(View view) {
            sendSMS();
         }
      });
   }

   protected void sendSMS() {
      Log.i("Send SMS", "");
      Intent smsIntent = new Intent(Intent.ACTION_VIEW);

      smsIntent.setData(Uri.parse("smsto:"));
      smsIntent.setType("vnd.android-dir/mms-sms");
      smsIntent.putExtra("address"  , new String ("01234"));
      smsIntent.putExtra("sms_body"  , "Test ");

      try {
         startActivity(smsIntent);
         finish();
         Log.i("Finished sending SMS...", "");
      } catch (android.content.ActivityNotFoundException ex) {
         Toast.makeText(MainActivity.this,
         "SMS faild, please try again later.", Toast.LENGTH_SHORT).show();
      }
   }


       @Override
       public boolean onCreateOptionsMenu(Menu menu) {
          // Inflate the menu; this adds items to the action bar if it is present.
          getMenuInflater().inflate(R.menu.main, menu);
          return true;
       }
    }

以下是 res / layout / activity_main.xml 文件的内容

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
   xmlns:tools="http://schemas.android.com/tools"
   android:layout_width="match_parent"
   android:layout_height="match_parent"
   android:paddingLeft="@dimen/activity_horizontal_margin"
   android:paddingRight="@dimen/activity_horizontal_margin"
   android:paddingTop="@dimen/activity_vertical_margin"
   android:paddingBottom="@dimen/activity_vertical_margin"
   tools:context=".MainActivity">

   <TextView
      android:layout_width="wrap_content"
      android:layout_height="wrap_content"
      android:text="Drag and Drop Example"
      android:id="@+id/textView"
      android:layout_alignParentTop="true"
      android:layout_centerHorizontal="true"
      android:textSize="30dp" />

   <TextView
      android:layout_width="wrap_content"
      android:layout_height="wrap_content"
      android:text="Tutorials Point "
      android:id="@+id/textView2"
      android:layout_below="@+id/textView"
      android:layout_centerHorizontal="true"
      android:textSize="30dp"
      android:textColor="#ff14be3c" />

   <ImageView
      android:layout_width="wrap_content"
      android:layout_height="wrap_content"
      android:id="@+id/imageView"
      android:src="@drawable/abc"
      android:layout_marginTop="48dp"
      android:layout_below="@+id/textView2"
      android:layout_centerHorizontal="true" />

   <Button
      android:layout_width="wrap_content"
      android:layout_height="wrap_content"
      android:text="Compose SMS"
      android:id="@+id/button"
      android:layout_below="@+id/imageView"
      android:layout_alignRight="@+id/textView2"
      android:layout_alignEnd="@+id/textView2"
      android:layout_marginTop="54dp"
      android:layout_alignLeft="@+id/imageView"
      android:layout_alignStart="@+id/imageView" />

</RelativeLayout>

以下是 res / values / strings.xml 的内容,用于定义两个新常量 -

<?xml version="1.0" encoding="utf-8"?>
<resources>
   <string name="app_name">codingdict</string>
</resources>

以下是 AndroidManifest.xml 的默认内容-

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
   package="com.example.codingdict" >

   <application
      android:allowBackup="true"
      android:icon="@drawable/ic_launcher"
      android:label="@string/app_name"
      android:theme="@style/AppTheme" >

      <activity
         android:name="com.example.codingdict.MainActivity"
         android:label="@string/app_name" >

         <intent-filter>
            <action android:name="android.intent.action.MAIN" />
            <category android:name="android.intent.category.LAUNCHER" />
         </intent-filter>

      </activity>

   </application>
</manifest>

让我们尝试运行您的 codingdict 应用程序。我假设您已将实际的Android移动设备与计算机相关联。要从Android工作室运行应用程序,请打开项目的某个活动文件,然后单击Eclipse运行图标工具栏中的“运行”图标。在开始申请之前,Android studio将显示以下窗口,以选择您要运行Android应用程序的选项。

Android移动设备

选择您的移动设备作为选项,然后检查您的移动设备,该设备将显示以下屏幕 -

Android手机短信撰写

现在使用 Compose SMS 按钮启动Android内置SMS客户端,如下所示 -

Android手机短信屏幕

您可以修改任一给定的默认字段,最后使用发送短信按钮将您的短信发送给提到的收件人。