资讯中心 / APP接入短信验证码功能介绍

APP接入短信验证码功能介绍

短信验证码
2018-11-22

短信验证码对于APP来说已经成为了必不可少的功能,新用户注册、快速验证登录、修改密码、安全支付验证等等场景都需要短信验证码来支撑。APP要具备短信验证码功能就必须通过短信接口来实现,目前最常见的做法就是选择一家短信平台合作,直接使用平台的接口接入APP,并通过平台的短信通道实现验证码的发送。市面上的短信平台都是按照验证码短信的条数计费的,那么有没有免费的呢?

 

Mob SMSSDK就是一个完全免费的短信验证码服务平台,只需要在你的APP内植入短信验证码SDK,简单设置就可以快速的实现APP的短信验证码功能。集成步骤如下(以android为例):

 

一、注册应用获取appKey 和 appSecret

(1)到Mob官网注册成为Mob开发者;

(2)到应用管理后台新建应用。

 

二、 集成SMSSDK

配置gradle

1、 打开项目根目录的build.gradle,在buildscrip–>dependencies 模块下面添加 classpath ‘com.mob.sdk:MobSDK:+’,如下所示;

buildscript {

repositories {

jcenter()

}

 

dependencies {

...

classpath 'com.mob.sdk:MobSDK:+'

 

}

}

 

2、 在使用SMSSDK模块的build.gradle中,添加MobSDK插件和扩展,如:

// 添加插件

apply plugin: 'com.mob.sdk'

 

// 在MobSDK的扩展中注册SMSSDK的相关信息

MobSDK {

appKey "d580ad56b4b5"

appSecret "7fcae59a62342e7e2759e9e397c82bdd"

 

SMSSDK {}

}

 

添加代码

1、初始化MobSDK

如果您没有在AndroidManifest中设置appliaction的类名,MobSDK会将这个设置为com.mob.MobApplication,但如果您设置了,请在您自己的Application类中调用:

MobSDK.init(this);

以初始化MobSDK。

 

 

2、发送验证码并取得验证结果

有两种方法完成验证码短信的发送和验证:调用可视化界面和使用无界面接口

 

2-1、以可视化界面完成操作

public void sendCode(Context context) {

RegisterPage page = new RegisterPage();

//如果使用我们的ui,没有申请模板编号的情况下需传null

page.setTempCode(null);

page.setRegisterCallback(new EventHandler() {

public void afterEvent(int event, int result, Object data) {

if (result == SMSSDK.RESULT_COMPLETE) {

// 处理成功的结果

HashMap<String,Object> phoneMap = (HashMap<String, Object>) data;

String country = (String) phoneMap.get("country"); // 国家代码,如“86”

String phone = (String) phoneMap.get("phone"); // 手机号码,如“13800138000”

// TODO 利用国家代码和手机号码进行后续的操作

} else{

// TODO 处理错误的结果

}

}

});

page.show(context);

}

 

2-2、以无界面接口完成操作

// 在尝试读取通信录时以弹窗提示用户(可选功能)

SMSSDK.setAskPermisionOnReadContact(true);

 

EventHandler eventHandler = new EventHandler() {

public void afterEvent(int event, int result, Object data) {

// afterEvent会在子线程被调用,因此如果后续有UI相关操作,需要将数据发送到UI线程

Message msg = new Message();

msg.arg1 = event;

msg.arg2 = result;

msg.obj = data;

new Handler(Looper.getMainLooper(), new Callback() {

@Override

public boolean handleMessage(Message msg) {

int event = msg.arg1;

int result = msg.arg2;

Object data = msg.obj;

if (event == SMSSDK.EVENT_GET_VERIFICATION_CODE) {

if (result == SMSSDK.RESULT_COMPLETE) {

// TODO 处理成功得到验证码的结果

// 请注意,此时只是完成了发送验证码的请求,验证码短信还需要几秒钟之后才送达

} else {

// TODO 处理错误的结果

((Throwable) data).printStackTrace();

}

} else if (event == SMSSDK.EVENT_SUBMIT_VERIFICATION_CODE) {

if (result == SMSSDK.RESULT_COMPLETE) {

// TODO 处理验证码验证通过的结果

} else {

// TODO 处理错误的结果

((Throwable) data).printStackTrace();

}

}

// TODO 其他接口的返回结果也类似,根据event判断当前数据属于哪个接口

return false;

}

}).sendMessage(msg);

}

};

// 注册一个事件回调,用于处理SMSSDK接口请求的结果

SMSSDK.registerEventHandler(eventHandler);

 

// 请求验证码,其中country表示国家代码,如“86”;phone表示手机号码,如“13800138000”

SMSSDK.getVerificationCode(country, phone);

 

// 提交验证码,其中的code表示验证码,如“1357”

SMSSDK.submitVerificationCode(country, phone, code);

 

// 使用完EventHandler需注销,否则可能出现内存泄漏

protected void onDestroy() {

super.onDestroy();

SMSSDK.unregisterEventHandler(eventHandler);

}

 

更多其他版本集成及Mob SMSSDK的具体功能可到Mob官网了解(http://www.mob.com/product/sms)。

上一篇 下一篇
SDK打包中 — 0%

SDK下载

正在根据您选择的SDK打包中,完成后自动下载
0%