情诗网 >情话短信 > 正文

Android 免费短信新姿势

来源:情诗网    2020-11-19    分类:情话短信

个人在开发的过程中,总想着怎么样去用最小的代价开发出来高质量的产品,但是对于一些较好资源总是存在收费情况,因此如何在将收费资源转换成免费资源就成了一种趋势。废话也不多说了,直接进入主题:
MobTech是全球领先的综合性智能科技企业,以数据应用为主导,融合顶尖的大数据、云计算、人工智能等多元先进技术,为全球多个国家和地区的企业、开发者和机构提供商业智能解决方案、App运营赋能方案、企业级AI智能方案、数据咨询研究等服务。
今天主要说明的是MobTech的免费短信SDK集成。

集成准备

1.注册应用申请Mob的 AppKey 和 AppSecret,详情可以点击查看注册流程

配置集成

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

buildscript {
    repositories {
        ...
    }
    dependencies {
        ...
        classpath "com.mob.sdk:MobSDK:2018.0319.1724"
    }
}
  1. 在使用SMSSDK模块的build.gradle中,添加MobSDK插件和扩展,如下所示:
// 添加插件
apply plugin: 'com.mob.sdk'

// 在MobSDK的扩展中注册SMSSDK的相关信息
MobSDK {
    appKey "申请Mob的appkey"
    appSecret "申请Mob的AppSecret"
    SMSSDK {}
}

代码调用

SMSSDK for Android

一.集成准备

1.注册应用申请Mob的 AppKey 和 AppSecret,详情可以点击查看注册流程

二.配置集成

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

buildscript {
    repositories {
        ...
    }
    dependencies {
        ...
        classpath "com.mob.sdk:MobSDK:2018.0319.1724"
    }
}
share1

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

// 添加插件
apply plugin: 'com.mob.sdk'

// 在MobSDK的扩展中注册SMSSDK的相关信息
MobSDK {
    appKey "申请Mob的appkey"
    appSecret "申请Mob的AppSecret"
    SMSSDK {}
}

三.代码调用

1.发送验证码并取得验证结果(如果提示489错误MD5错误请点击这里
目前SMSSDK提供两套接口方案,一种是默认的UI集成即可,如下1-1所示;另一种是不使用我们的UI,直接调用发送和验证接口,如下1-2所示;
1-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;
                // 国家代码,如“86”
                String country = (String) phoneMap.get("country"); 
                // 手机号码,如“13800138000”
                String phone = (String) phoneMap.get("phone"); 
                // TODO 利用国家代码和手机号码进行后续的操作
            } else{
                // TODO 处理错误的结果
            }
        }
    });
    page.show(context);
}

Kotin 版本

fun sendCode(context: Context) {
    val page = RegisterPage()
    //如果使用我们的ui,没有申请模板编号的情况下需传null
    page.setTempCode(null)
    page.setRegisterCallback(object : EventHandler() {
        fun afterEvent(event: Int, result: Int, data: Any) {
            if (result == SMSSDK.RESULT_COMPLETE) {
                // 处理成功的结果
                val phoneMap = data as HashMap<String, Any>
                // 国家代码,如“86”
                val country = phoneMap["country"] as String 
                // 手机号码,如“13800138000”
                val phone = phoneMap["phone"] as String 
                // TODO 利用国家代码和手机号码进行后续的操作
            } else {
                // TODO 处理错误的结果
            }
        }
    })
    page.show(context)
}

1-2、以无界面接口完成操作
a.注册监听回调,后面执行发送验证的时候才能正常收到回调

EventHandler eh=new EventHandler(){
@Override
    public void afterEvent(int event, int result, Object data) {
        // TODO 此处不可直接处理UI线程,处理后续操作需传到主线程中操作
        Message msg = new Message();
        msg.arg1 = event;
        msg.arg2 = result;
        msg.obj = data;
        mHandler.sendMessage(msg);

    }
};


//注册一个事件回调监听,用于处理SMSSDK接口请求的结果
SMSSDK.registerEventHandler(eh);

Kotin 版本

val eh = object : EventHandler() {
      override fun afterEvent(event: Int, result: Int, data: Any?) {
            // TODO 此处不可直接处理UI线程,处理后续操作需传到主线程中操作
            val msg = Message()
            msg.arg1 = event
            msg.arg2 = result
            msg.obj = data
            mHandler.sendMessage(msg)
       }
}

//注册一个事件回调监听,用于处理SMSSDK接口请求的结果
SMSSDK.registerEventHandler(eh)

如上,后续判断回调类型可参考文档 无GUI接口调用

b.发送验证码,具体参数可以参考 无GUI接口调用

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

c.验证验证码,具体参数可以参考 无GUI接口调用

// 提交验证码,其中的code表示验证码,如“1357”
SMSSDK.submitVerificationCode(country, phone, code);

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

protected void onDestroy() {
    super.onDestroy();
    SMSSDK.unregisterEventHandler(eventHandler);
}

混淆设置

混淆设置:SMSSDK已经做了混淆处理,再次混淆会导致不可预期的错误,请在您的混淆脚本中添加如下的配置,跳过对SMSSDK的混淆操作:

-keep class com.mob.**{*;}
-keep class cn.smssdk.**{*;}
-dontwarn com.mob.**

注意事项

SMSSDK默认会添加一套开源的GUI库,如果您不需要这个库,可以在SMSSDK下设置“gui false”来关闭它
若使用GUI的自动填充验证码功能,需在SMSSDK{}中打开此设置 “autoSMS true ”
MobSDK默认为SMSSDK提供最新版本的集成,如果您想锁定某个版本,可以在SMSSDK{}中设置“version “某个版本””来固定使用这个版本
在尝试读取通信录时以弹窗提示用户(可选功能),在监听回调前调用即可;

SMSSDK.setAskPermisionOnReadContact(true);

如果使用MobSDK的模块会被其它模块依赖,请确保依赖它的模块也引入MobSDK插件,或在此模块的gradle中添加:

repositories {
    jcenter()
}

热门文章