Android用 Mob 实现发送短信验证码实例

和室友参加的互联网大赛要做一个 APP,涉及到用户的登录注册,于是上网找了许多资料,其中有阿里大于,网易云等等,阿里大于的客服给我说他们不支持 Android,网易云还要拍手持身份证的照片,而且这两个都收费,还麻烦,于是找了一个既简单有免费的,叫做 Mob,官网如下

Mob 官网

官方文档看了很多,还是觉得写的不好,于是自己写一篇。

注册账号

在 Mob 官网右上角点击注册,依次填入信息,其中公司一栏可以随便填

添加应用

登录后,点击 SecurityCodeSDK - 立即使用,Mob 会提示你添加应用,名字自己填,再选 Android,添加完后再点击 SecurityCodeSDk - 进入,之后应该可以看到如下界面

AppKey 和 AppSecret 一会会用到

下载 SDK

在网页上方“下载SDK”中点击“免费短信验证码SDK”,网页跳转后找到“短信验证码SDK”,根据需要选择系统吧,我做的 Android 就选 Android,网页跳转后根据需要选择 AndroidStudio 或者 eclipse,在屏幕右方选择,选好后点击即可开始下载。

下好后解压,打开文件夹,目录结构如下

要用到的 SDK 在 SMSSDK 文件夹中

导入 SDK 到工程目录

打开 SMSSDK 文件夹,把两个 .jar 和 .aar 文件复制到工程目录中 libs 文件夹下,如图所示

粘贴进去后,选中两个 .jar 文件,右键点击,选择 add as library

再打开 app 目录下的 build.gradle,添加如下两处内容

repositories{
  flatDir{
    dirs 'libs'
  }
}
compile name:'SMSSDK-2.1.4',ext:'aar'
compile name:'SMSSDKGUI-2.1.4',ext:'aar'

最后看起来是这样的

添加的代码为 22-26 行和 36-37 行。

打开 AndroidManifest.xml,添加如下权限

<uses-permission android:name="android.permission.READ_CONTACTS" />
<uses-permission android:name="android.permission.READ_PHONE_STATE" />
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />
<uses-permission android:name="android.permission.ACCESS_WIFI_STATE" />
<uses-permission android:name="android.permission.INTERNET" />
<uses-permission android:name="android.permission.RECEIVE_SMS" />
<uses-permission android:name="android.permission.READ_SMS" />
<uses-permission android:name="android.permission.GET_TASKS" />
<uses-permission android:name="android.permission.ACCESS_FINE_LOCATION" />

程序代码

先把完整代码贴出来(没贴 xml,这个不影响)

public class Register extends AppCompatActivity implements View.OnClickListener {

  private EditText etPhoneNumber;    // 电话号码
  private Button sendVerificationCode;  // 发送验证码
  private EditText etVerificationCode;  // 验证码
  private Button nextStep;        // 下一步

  private String phoneNumber;     // 电话号码
  private String verificationCode;  // 验证码

  private boolean flag;  // 操作是否成功

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

    init(); // 初始化控件、注册点击事件

    final Context context = Register.this;            // context
    final String AppKey = "你的 AppKey";            // AppKey
    final String AppSecret = "你的 AppSecret"; // AppSecret

    SMSSDK.initSDK(context, AppKey, AppSecret);      // 初始化 SDK 单例,可以多次调用
    EventHandler eventHandler = new EventHandler(){    // 操作回调
      @Override
      public void afterEvent(int event, int result, Object data) {
        Message msg = new Message();
        msg.arg1 = event;
        msg.arg2 = result;
        msg.obj = data;
        handler.sendMessage(msg);
      }
    };
    SMSSDK.registerEventHandler(eventHandler);   // 注册回调接口
  }

  private void init() {
    etPhoneNumber = (EditText) findViewById(R.id.edit_phone_number);
    sendVerificationCode = (Button) findViewById(R.id.btn_send_verification_code);
    etVerificationCode = (EditText) findViewById(R.id.edit_verification_code);
    nextStep = (Button) findViewById(R.id.btn_next_step);
    sendVerificationCode.setOnClickListener(this);
    nextStep.setOnClickListener(this);
  }

  @Override
  public void onClick(View v) {
    switch (v.getId()) {
      case R.id.btn_send_verification_code:
        if (!TextUtils.isEmpty(etPhoneNumber.getText())) {
          if (etPhoneNumber.getText().length() == 11) {
            phoneNumber = etPhoneNumber.getText().toString();
            SMSSDK.getVerificationCode("86", phoneNumber); // 发送验证码给号码的 phoneNumber 的手机
            etVerificationCode.requestFocus();
          }
          else {
            Toast.makeText(this, "请输入完整的电话号码", Toast.LENGTH_SHORT).show();
            etPhoneNumber.requestFocus();
          }
        } else {
          Toast.makeText(this, "请输入电话号码", Toast.LENGTH_SHORT).show();
          etPhoneNumber.requestFocus();
        }
        break;

      case R.id.btn_next_step:
        if (!TextUtils.isEmpty(etVerificationCode.getText())) {
          if (etVerificationCode.getText().length() == 4) {
            verificationCode = etVerificationCode.getText().toString();
            SMSSDK.submitVerificationCode("86", phoneNumber, verificationCode);
            flag = false;
          } else {
            Toast.makeText(this, "请输入完整的验证码", Toast.LENGTH_SHORT).show();
            etVerificationCode.requestFocus();
          }
        } else {
          Toast.makeText(this, "请输入验证码", Toast.LENGTH_SHORT).show();
          etVerificationCode.requestFocus();
        }
        break;

      default:
        break;
    }
  }

  Handler handler = new Handler() {
    @Override
    public void handleMessage(Message msg) {
      super.handleMessage(msg);
      int event = msg.arg1;
      int result = msg.arg2;
      Object data = msg.obj;

      if (result == SMSSDK.RESULT_COMPLETE) {
        // 如果操作成功
        if (event == SMSSDK.EVENT_SUBMIT_VERIFICATION_CODE) {
          // 校验验证码,返回校验的手机和国家代码
          Toast.makeText(Register.this, "验证成功", Toast.LENGTH_SHORT).show();
          Intent intent = new Intent(Register.this, MainActivity.class);
          startActivity(intent);
        } else if (event == SMSSDK.EVENT_GET_VERIFICATION_CODE) {
          // 获取验证码成功,true为智能验证,false为普通下发短信
          Toast.makeText(Register.this, "验证码已发送", Toast.LENGTH_SHORT).show();
        } else if (event == SMSSDK.EVENT_GET_SUPPORTED_COUNTRIES) {
          // 返回支持发送验证码的国家列表
        }
      } else {
        // 如果操作失败
        if (flag) {
          Toast.makeText(Register.this, "验证码获取失败,请重新获取", Toast.LENGTH_SHORT).show();
          etPhoneNumber.requestFocus();
        } else {
          ((Throwable) data).printStackTrace();
          Toast.makeText(Register.this, "验证码错误", Toast.LENGTH_SHORT).show();
        }
      }
    }
  };

  @Override
  protected void onDestroy() {
    super.onDestroy();
    SMSSDK.unregisterAllEventHandler(); // 注销回调接口
  }
}

注意要把你的 AppKey 和 AppSecret 替换进去。

其实看过很多教程你会发现,很多时候并不是代码看不懂,而是在配置文件的时候出了问题,因为一个刚接触 Android 没两天的人是不可能对很多第三方 SDK 有需求的,一开始都是以基础为主,所以需要配置第三方 SDK 的很多都是写过一些 Android 代码的人,他们所关心的其实就是该调用哪些方法来实现自己的目的,所以知道怎么调用就行了,再根据实际需求写几个 if-else 就可以了。

注意

SMSSDK.initSDK(context, AppKey, AppSecret);      // 初始化 SDK 单例,可以多次调用
EventHandler eventHandler = new EventHandler(){    // 操作回调
  @Override
  public void afterEvent(int event, int result, Object data) {
    Message msg = new Message();
    msg.arg1 = event;
    msg.arg2 = result;
    msg.obj = data;
    handler.sendMessage(msg);
  }
};
SMSSDK.registerEventHandler(eventHandler);   // 注册回调接口

这几行代码是调用这个 SDK 的基础,写在 onCreate 中。

发送短信验证码的语句是

SMSSDK.getVerificationCode("86", phoneNumber);

phoneNumber 的取值取决于用户输入的号码,“86”是中国的区号,根据需求也可以让用户自己选择,稍微修改一下就行。

if (result == SMSSDK.RESULT_COMPLETE) {
  // 如果操作成功
  if (event == SMSSDK.EVENT_SUBMIT_VERIFICATION_CODE) {
  // 校验验证码,返回校验的手机和国家代码
    Toast.makeText(Register.this, "验证成功", Toast.LENGTH_SHORT).show();
    Intent intent = new Intent(Register.this, MainActivity.class);
    startActivity(intent);
  } else if (event == SMSSDK.EVENT_GET_VERIFICATION_CODE) {
    // 获取验证码成功,true为智能验证,false为普通下发短信
    Toast.makeText(Register.this, "验证码已发送", Toast.LENGTH_SHORT).show();
  } else if (event == SMSSDK.EVENT_GET_SUPPORTED_COUNTRIES) {
    // 返回支持发送验证码的国家列表
  }
} else {
  // 如果操作失败
  if (flag) {
    Toast.makeText(Register.this, "验证码获取失败,请重新获取", Toast.LENGTH_SHORT).show();
    etPhoneNumber.requestFocus();
  } else {
    ((Throwable) data).printStackTrace();
    Toast.makeText(Register.this, "验证码错误", Toast.LENGTH_SHORT).show();
  }
}

这几行代码判断验证码发没发送以及正不正确,根据 event 来确定是哪一种情况,如果想深入了解,可以参考官方文档

Android 短信SDK操作回调

当然,免费服务肯定收费的要差点,体现在短信发的比收费的慢,大概要十秒才能收到,收费的三秒就收到了,由于只是个比赛,自己做着玩,用免费的足矣。

另外,最开始免费的时候每天只能发 20 条短信,而且一个手机号每 12 小时只能收到 5 条,所以,省着点用,当然你可以在应用管理界面申请上线登记(见第一张图),审核通过后就完全免费了。

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

时间: 2017-06-04

Android实现短信验证码自动拦截读取功能

知识准备:  1.观察者模式的理解[文章稍后来到~~]  2.Android的Cursor使用[Android基础]  3.正则表达式使用[Java基础]  4.Handler使用[Android基础] 代码整理: MainActivity.java import android.net.Uri; import android.os.Bundle; import android.os.Handler; import android.os.Message; import android.suppo

Android实现短信验证码自动填写功能

本实例为大家分享了Android实现短信验证码自动填写功能,供大家参考,具体内容如下 实现思路很简单: 1.在需要输入验证码的Activity代码注册监听短信的广播 2.拦截短信,获取其中的验证码 3.回写到EditText private SmsReciver smsReciver = new SmsReciver(); /** 收到短信Action **/ String ACTION_SMS_RECIVER = "android.provider.Telephony.SMS_RECEIVED

Android&#8203;短信验证码倒计时验证的2种常用方式

前言 ​本文主要介绍的是短信验证码功能,这里总结了两种常用的方式,可以直接拿来使用. 看图 计时器 说明:这里的及时从10开始,是为了演示的时间不要等太长而修改的. 方法如下 1.第一种方式:Timer /** * Description:自定义Timer * <p> * Created by Mjj on 2016/12/4. */ public class TimeCount extends CountDownTimer { private Button button; //参数依次为总时

Android获取和读取短信验证码的实现方法

现如今,验证码在Android的客户端还是非常普遍的.通过手机账号和验证码直接去注册应用账户的信息.很多应用都以这种方式来完成注册.简单的介绍一下吧. Android获取短信验证码还是比较简单的,通过Mob官网提供的ShareSDK,调用其中内部的方法,就可以获取到短信的验证码了.提供一下Mob的官网地址.http://www.mob.com/#/在官网上注册相关的信息之后,下载相关的jar包和.so文件就可以实现获取短信验证码了(2.0之前的版本都需要下载jar包和 .so文件,而现在的2.2

关于Android短信验证码的获取的示例

最近突然想起App里面的登录模块,有可以使用手机号码注册的功能,感觉此功能在大多款App里面都比较常见,因此在此做一个记录,顺便将之前踩过得坑在此记录一下,之前一直没有在简书上面写过文章,感觉慌慌哒.好了,下面开始记录下我的过程. 先放上最终的效果图: 我去,这上传的效果也不是太好,各位看官请见谅,不过基本的功能还是有了的,不妨碍后面的阅读. 下面我将一步步介绍如何实现这个功能的. 首先我使用的是容联云平台的短信验证,做这个之前需要先注册一个开发者账号,然后下载里面的一个demo,可以它的看看介

Android实现短信验证码获取自动填写功能(详细版)

现在的应用在注册登录或者修改密码中都用到了短信验证码,那在android中是如何实现获取短信验证码并自动填写的呢? 首先,需要要在manifest中注册接收和读取短信的权限: <uses-permission android:name="android.permission.RECEIVE_SMS"></uses-permission> <uses-permission android:name="android.permission.READ_

Android获取短信验证码的实现方法

先给大家展示下效果图,如果感觉不错,请参考实现思路详解 Android开发中关于短息验证码的设计层出不穷,越来越多的应用为了更好的提高软件的安全性,开始使用通过服务器向用户发送验证码的方式,来保护用户个人信息的安全性.无论是用户注册时的信息验证还是当用户发出找回密码请求时的短信验证,他们的工作原理大致上是一致的,因为项目的需要研究了一下关于这方面的知识,本篇我将带领大家一起实现这一当下流行的设计方案. 众所周知,短信验证需要服务器端生成一个验证码,然后发送到用户输入的手机上,这个过程需要服务器主

Android实现自动提取短信验证码功能

本文实例讲解了Android自动提取短信验证码解决方案,分享给大家供大家参考,具体内容如下 主要功能及优点 1.收到验证码短信后,自动提取短信中的验证码填写到相应输入框 2.可指定一个号码,只读取与他有关短信,避免提取来源错误 3.利用正则表达式,可匹配各种类型验证码 模块集成关键步骤     将auto_getcode_demo中src包里的SMSContentObserver类复制到你的项目src包中 在SMSContentObserver中:    修改正则表达式内容来匹配自己想要获取的字

Android如何通过手机自动获取短信验证码

本文实例为大家分享了Android实现手机自动获取短信验证码功能,供大家参考,具体内容如下 1.短信监听广播 2.读取短信内容 3.截取短信内容[可以 reg截取] 4.填写至相应控件 PS:DevStore测试没有获取到验证码 源码片段 public class MainActivity extends Activity { private BroadcastReceiver smsReceiver; private IntentFilter filter2; private Handler

Android注册登录实时自动获取短信验证码

android应用的自动化测试必然会涉及到注册登录功能,而许多的注册登录或修改密码功能常常需要输入短信验证码,因此有必要能够自动获得下发的短信验证码. 主要就是实时获取短信信息. android上获取短信信息主要有BroadcastReceiver方式与数据库方式,要实时的话就BroadcastReceiver比较方便,分享一篇文章大家可以查看一下,点击. public class SMSReceiver extends BroadcastReceiver{ private String ver

Android自动获取短信验证码功能

先给大家展示下效果图,如果大家感觉不错,请参考实现代码. 1.自定义监听类 /** * 短信监听器,用于自动填充验证码 */ public class SMSContentObserver extends ContentObserver { public final String SMS_URI_INBOX = "content://sms/inbox";//收信箱 private Activity activity = null; private String smsContent

Android手机号注册、绑定手机号获取短信验证码实例

本文写了一个常见的功能--手机app中注册或绑定手机号的获取验证码的功能,也就是短信验证功能 具体效果就是,你在注册界面填写手机号,点击获取验证码按钮,---然后会收到验证短信,填入验证码后点击注册按钮,如果验证正确就可以跳转到另外一个界面 1.首先大家需要在mob官网注册一个账号,mob是一个免费的短信验证平台 2.在mob.com后台创建应用 3.下载对应的sdk 4.将sdk作为一个library导入到你的项目中 5.现在就可以在你的项目中编写代码使用mob提供的这个功能了 具体代码如下:

Android自动填充短信验证码功能(demo)

项目需求: Android开发中用户登录往会用到短信验证的功能,如果让用户先查看短信,然后再回到界面填写验证码,用户体验不是很好,有时就需要实现验证码的自动填写功能. 做法: 我以前的做法是先创建一个广播接收器,接受短信变化的广播,收到广播时,再把验证码提取出来. 那时有用户测试反馈他的手机安装了其他一些短信应用或者手机本身限制了权限的情况下,这种方式可能起不了作用,即使把优先级设高,也不能保证不会被别的应用抢先. 以前用户卸载掉第三方软件后,就没再追究了. 现在发现可以通过监听短信数据库的方式

Android利用广播接收器实现自动填充短信验证码

今天博主带给小伙伴们一个小功能,就是利用广播接收器实现自动填充短信验证码,话不多说,我们先看看如何去实现这个小功能. 首先我们需要新建一个名为SMSBroadcastReceiver的广播接收器,代码如下: public class SMSBroadcastReceiver extends BroadcastReceiver { private static MessageListener mMessageListener; public SMSBroadcastReceiver() { sup

Android实现自动填充短信验证码

本文实例为大家分享了Android自动填充短信验证码的具体代码,供大家参考,具体内容如下 短信验证码是大部分软件里面都存在的功能,同时为了避免用户自己输入导致的繁琐操作,有一部分app设计者将其设置成了自动填充的方式,方便用户操作那么这种方式是什么实现的呢. 利用广播接收器来拦截短信获取其中匹配的内容,提供回掉,将短信内容暴露到activity中实现自动填充 首先我们要实现一个广播接收器 package com.wquant.weilt.reciver; import java.util.reg

Android开发之获取短信验证码后按钮背景变化并且出现倒计时

目前越来越多的app在注册或是进行对应操作时,要求获取短信验证码,在点击了获取短信验证码的按钮后,就是出现倒计时,比如倒计时120S,在倒计时期间内,按钮背景变化并且出现倒计时,当倒计时结束后,如果你没有获取到验证码,可以再次点击. 代码如下所示: VerCodeTimer mVerCodeTimer=(Button) findViewById(R.id.login_get_ver_code); private class VerCodeTimer extends CountDownTimer

JS实现用户注册时获取短信验证码和倒计时功能

在用户注册时,通常需要短信验证码,而且为了交互效果,也需要增加倒计时. 效果如下: <div class="user-form"> <form action="{{ path('zm_member_register') }}" method="post"> <div class="form-list"> <label class="register-label"&g