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 条,所以,省着点用,当然你可以在应用管理界面申请上线登记(见第一张图),审核通过后就完全免费了。

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

时间: 2024-07-29 17:03:00

Android用 Mob 实现发送短信验证码实例的相关文章

Android使用第三方服务器Bmob实现发送短信验证码_Android

调用Bmob第三方服务器实现短信验证的功能,大致思路如下: 随机产生6位数字,然后调用Bmob的请求短发函数发送者六位数到服务器,然后服务器给指定手机发送这6位验证码,然后感觉用户输入的数字进行判断,如果输入的和发送的相等,则验证成功. 第一步.请求验证码: SimpleDateFormat format =new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); String sendTime = format.format(new Date());

Android实现发送短信验证码倒计时功能示例

一.简介: 开发中在用户注册或找回密码之类的功能,经常会遇到获取短信验证码,获取验证码后需要等待1分钟倒计时,这段时间是不能再次发送短信请求的. 效果图: 二.实现步骤: 1.一个关键类:CountDownTimer(Android系统自带的倒计时功能类) public class CountDownTimerUtils extends CountDownTimer { private TextView mTextView; //显示倒计时的文字 /** * @param textView Th

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

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

Android开发中实现发送短信的小程序示例_Android

上图为代码结构图. 现在我们看下具体的代码. Send.java package cn.com.sms.send; import java.util.ArrayList; import java.util.Iterator; import android.app.Activity; import android.app.PendingIntent; import android.content.Intent; import android.os.Bundle; import android.te

php发送短信验证码完成注册功能_php实例

短信验证码注册,很简单,用的是  云通讯的短信系统(收费的,不过有测试的api给我们做测试).好了,不多说,进入正题.  1.收到到云通讯短信系统注册账号,然后下载他们的封装好的短信api接口代码,解压,然后找到CCPRestSDK.php文件和SendTemplateSMS.php文件,将其拉到根目录文件夹里. 2.打开SendTemplateSMS.php文件,首先注意include_once('./CCPRestSDK.php'),千万别包含错路径了,将云通讯给的测试主账号,主账号Toke

基于jQuery实现发送短信验证码后的倒计时功能(无视页面关闭)_jquery

相关阅读: 基于JS实现发送短信验证码后的倒计时功能(无视页面刷新,页面关闭不进行倒计时功能) 今天测试提了一个bug,发送短信倒计时功能,要求关闭页面也要进行倒计时.这想到了,当年我参与的周杰伦演唱会的先付先抢功能.与之类似,只不过,那个项目的时间都是服务器时间,本人目前有点偷懒,就用客户端的时间了. 一下是完整的代码,只不过在客户端的效率不是很好. <!doctype html> <html lang="en"> <head> <meta

基于JS实现发送短信验证码后的倒计时功能(无视页面刷新,页面关闭不进行倒计时功能)_javascript技巧

相关阅读: 基于jQuery实现发送短信验证码后的倒计时功能(无视页面关闭) 下面一段代码是小编给大家带来的js发送短信验证码后实现倒计时功能,代码简单易懂. 具体代码如下所示: <!doctype html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="Generator" content="EditPlus

javascript发送短信验证码实现代码_javascript技巧

本文首先分析手机发送验证码的原理,再对javascript发送短信验证码予以实现,具体思路如下: 实现点击"发送验证码"按钮后,按钮依次显示为"59秒后重试"."58秒后重试"-直至倒计时至0秒时再恢复显示为"发送验证码".在倒计时期间按钮为禁用状态 . 第一步.获取按钮.绑定事件.设置定时器变量和计时变量 第二步.添加定时器,每隔1秒钟计时减 1,直至当计时小于等于 0 时清除定时器,按钮恢复为"发送验证码&quo

通过第三方接口发送短信验证码/短信通知(推荐)_java

需求:将首次交付密码为公共默认密码的方式改为点击入职功能,用短信方式发送系统自动生成的八位含数字.大小写字母和特殊符号生成的密码.短信发送服务由云通信http://www.yuntongxun.com/提供. 随机密码生成方法: /** * 生成随即密码 * @author chao.gao * @param pwd_len 生成的密码的总长度 * @return 密码的字符串 */ public static String genRandomNum(int pwd_len) { // Stri