项目中集成MOB.com提供的三方短信SDK.
当然这些短信都是免费的.并且可以在您申请的MOB.com后台去查看短信注册用户的相关信息.
这篇文后半部分会提供一个简单的验证短信Demo,有界面,当然界面不喜欢的话您可以自定义;
先开始咱们的相关配置步骤:
第一步(账号的注册):
想用人MOB.com提供给大家的免费短信SDK,首先当然是注册成为MOB.com的用户.点击MOB用户注册界面直接开始注册.一共为三个步骤:由最初的账号信息的填写,直到最终的激活完成.
第二步(SDK的选择):
激活完成后自动跳转至MOB.com主页面点击右上角进入后台.有四个选项供咱们选择:
第三步(项目的创建):
咱们需要的是短信SDK.即MOB.com提供的SecurityCodeSDK功能.点击之后第一次会弹出提示框来提示您输入应用的名称,并选择好Android或ios选项,本文介绍的为Android集成,建议第一次先写个小Demo来实验一下.成功之后再弄成您的工作项目名称.完成之后如下图:
最上方三个标记处从左至右依次为您创建的应用名称,应用的AppKey,应用的AppSecret;
下方有一个快速集成选项.如果您使用的是AndroidStudio集成的话,看我的跟看官方文档一样快速;
但是还有一个提示为您的应用还未上线登记,每天只能发布20条短信.这个不用着急.等咱们把项目打包好后提交至MOB.com,经过审核通过之后,短信条数就会变为无限制了;
必须要添加:
SMSSDK 2.0.1 jar包下载地址.下载完成后解压,把其中的4个文件Copy之后放入您的项目主工程下的libs文件夹中,然后右键点击任意jar包后选择下方倒数第二行的add As Library选项.即可开始添加依赖.
必须要添加: 在项目主工程下的build.gradle下添加如下:
repositories{
flatDir{
dirs 'libs'
}
}
在dependencies中添加如下两行依赖:
compile files('libs/MobCommons-2016.1201.1839.jar')
compile files('libs/MobTools-2016.1201.1839.jar')
PS:
如果您是老版本,依赖可能没有自动生成,您需要在项目工程的build.gradle下添加如下这一句依赖:
compile fileTree(include: ['*.jar'],dir:'libs')
这句话的意思就是编译时依赖libs文件夹下的所有jar文件.
必须要添加:
然后到了咱们的配置清单文件AndroidMainifest.xml的时候了:
<uses-permission android:name="android.permission.READ_CONTACTS" />
<uses-permission android:name="android.permission.READ_PHONE_STATE" />
<uses-permission android:name="android.permission.WRITEAL_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" />
必须要添加:
在application标签中添加如下activity标签(报红色显示异常也没事):
<activity
android:name="com.mob.tools.MobUIShell"
android:theme="@android:style/Theme.Translucent.NoTitleBar"
android:configChanges="keyboardHidden|orientation|screenSize"
android:windowSoftInputMode="stateHidden|adjustResize"/>
必须要添加:
在项目启动时添加如下:
SMSSDK.initSDK(this, "您的appkey", "您的appsecret");
至此,前期的配置工作已经全部完成.
----------------------------------------------------------------------------
PS:
之前还在纠结这是不是个文字游戏:我是把这个初始化的操作放到Activity的onCreate中,还是把他放到Application的onCreate中呢?后来看到大神给的一番回答也就释然了:
咱们都知道,程序的入口是在Application的onCreate中,全局的初始化操作都会写在其中,如果咱们想让这个SMSSDK全局都可以使用,咱们就放到Application的onCreate中,如果说咱们只需要在某个界面使用,那就可以把他放到Activity的onCreate中。
下面开始介绍Demo的源码,您可以直接Copy或参考部分。
Demo截图:
如上图,当咱们输入手机号然后点击获取验证码的按钮时,会先把手机号取出来验证手机号的准确性后,
通过SMSSDK.getVerificationCode("86", phoneNums)发送至MOB.com的后台;
那怎么接收到短信验证码呢?MOB.com提供了相关的回调接口:Android 短信SDK操作回调
在onCreate中通过SMSSDK.registerEventHandler(eventHandler)注册该回调接口;
在onDestory中通过SMSSDK.unregisterAllEventHandler()反注册该回调接口;
咱们在后台可以查看注册短信验证用户的相关模糊信息。
默认情况MOB.com会给咱们的应用后台会开启智能验证,就是说短时间内,一个手机号码只能获取一次验证码,而不能频繁的接收验证码,打开短信设置选项,在页面最下面可以选择关闭.
MainActivity的源代码如下:
.
public class MainActivity extends AppCompatActivity implements View.OnClickListener{
String APPKEY = "您的AppKey";
String APPSECRET = "您的AppSecret";
// 手机号输入框
private EditText inputPhoneEt;
// 验证码输入框
private EditText inputCodeEt;
// 获取验证码按钮
private Button requestCodeBtn;
// 注册按钮
private Button commitBtn;
//倒计时显示 可以手动更改。
int i = 30;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
initView();
}
/**
* 初始化控件
*/
private void initView() {
inputPhoneEt = (EditText) findViewById(R.id.login_input_phone_et);
inputCodeEt = (EditText) findViewById(R.id.login_input_code_et);
requestCodeBtn = (Button) findViewById(R.id.login_request_code_btn);
commitBtn = (Button) findViewById(R.id.login_commit_btn);
requestCodeBtn.setOnClickListener(this);
commitBtn.setOnClickListener(this);
// 启动短信验证sdk
SMSSDK.initSDK(this, APPKEY, APPSECRET);
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);
}
@Override
public void onClick(View v) {
String phoneNums = inputPhoneEt.getText().toString(); //取出咱们输入的手机号
switch (v.getId()) {
case R.id.login_request_code_btn:
// 1. 判断手机号是不是11位并且看格式是否合理
if (!judgePhoneNums(phoneNums)) {
return;
} // 2. 通过sdk发送短信验证
SMSSDK.getVerificationCode("86", phoneNums);
// 3. 把按钮变成不可点击,并且显示倒计时(正在获取)
requestCodeBtn.setClickable(false);
requestCodeBtn.setText("重新发送(" + i + ")");
new Thread(new Runnable() {
@Override
public void run() {
for (; i > 0; i--) {
handler.sendEmptyMessage(-9);
if (i <= 0) {
break;
}
try {
Thread.sleep(1000);
} catch (InterruptedException e) {
e.printStackTrace();
}
}
handler.sendEmptyMessage(-8);
}
}).start();
break;
case R.id.login_commit_btn:
//将收到的验证码和手机号提交再次核对
SMSSDK.submitVerificationCode("86", phoneNums, inputCodeEt
.getText().toString());
break;
}
}
/**
*
*/
Handler handler = new Handler() {
public void handleMessage(Message msg) {
if (msg.what == -9) {
requestCodeBtn.setText("重新发送(" + i + ")");
} else if (msg.what == -8) {
requestCodeBtn.setText("获取验证码");
requestCodeBtn.setClickable(true);
i = 30;
} else {
int event = msg.arg1;
int result = msg.arg2;
Object data = msg.obj;
Log.e("event", "event=" + event);
if (result == SMSSDK.RESULT_COMPLETE) {
// 短信注册成功后,返回MainActivity,然后提示
if (event == SMSSDK.EVENT_SUBMIT_VERIFICATION_CODE) {// 提交验证码成功
Toast.makeText(getApplicationContext(), "提交验证码成功",
Toast.LENGTH_SHORT).show();
Intent intent = new Intent(MainActivity.this,
Main2Activity.class);
Bundle bundle = new Bundle();
bundle.putString("userName",inputPhoneEt.getText().toString().trim());
intent.putExtras(bundle);
startActivity(intent);
} else if (event == SMSSDK.EVENT_GET_VERIFICATION_CODE) {
Toast.makeText(getApplicationContext(), "正在获取验证码",
Toast.LENGTH_SHORT).show();
} else {
((Throwable) data).printStackTrace();
}
}
}
}
};
/**
* 判断手机号码是否合理
*
* @param phoneNums
*/
private boolean judgePhoneNums(String phoneNums) {
if (isMatchLength(phoneNums, 11)
&& isMobileNO(phoneNums)) {
return true;
}
Toast.makeText(this, "手机号码输入有误!",Toast.LENGTH_SHORT).show();
return false;
}
/**
* 判断一个字符串的位数
* @param str
* @param length
* @return
*/
public static boolean isMatchLength(String str, int length) {
if (str.isEmpty()) {
return false;
} else {
return str.length() == length ? true : false;
}
}
/**
* 验证手机格式
*/
public static boolean isMobileNO(String mobileNums) {
/*
* 移动:134、135、136、137、138、139、150、151、157(TD)、158、159、187、188
* 联通:130、131、132、152、155、156、185、186 电信:133、153、180、189、(1349卫通)
* 总结起来就是第一位必定为1,第二位必定为3或5或8,其他位置的可以为0-9
*/
String telRegex = "[1][358]\\d{9}";// "[1]"代表第1位为数字1,"[358]"代表第二位可以为3、5、8中的一个,"\\d{9}"代表后面是可以是0~9的数字,有9位。
if (TextUtils.isEmpty(mobileNums))
return false;
else
return mobileNums.matches(telRegex);
}
@Override
protected void onDestroy() {
//反注册回调监听接口
SMSSDK.unregisterAllEventHandler();
super.onDestroy();
}
}
.
MainActivity的布局文件如下:
.
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical">
<EditText
android:id="@+id/login_input_phone_et"
android:layout_width="280dp"
android:layout_height="wrap_content"
android:layout_alignParentTop="true"
android:layout_centerHorizontal="true"
android:layout_marginTop="107dp"
android:ems="10"
android:hint="请输入手机号"
android:inputType="phone" />
<requestFocus />
<EditText
android:id="@+id/login_input_code_et"
android:layout_width="170dp"
android:layout_height="wrap_content"
android:layout_alignLeft="@+id/login_input_phone_et"
android:layout_below="@+id/login_input_phone_et"
android:layout_marginTop="44dp"
android:hint="请输入验证码"
android:inputType="textPassword"></EditText>
<Button
android:id="@+id/login_request_code_btn"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignRight="@+id/login_input_phone_et"
android:layout_alignTop="@+id/login_input_code_et"
android:text="获取验证码" />
<Button
android:id="@+id/login_commit_btn"
android:layout_width="280dp"
android:layout_height="wrap_content"
android:layout_alignLeft="@+id/login_input_code_et"
android:layout_below="@+id/login_input_code_et"
android:layout_marginTop="44dp"
android:text="注册" />
</RelativeLayout>
.
.
public class Main2Activity extends AppCompatActivity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main2);
Bundle extras = getIntent().getExtras();
String userName = extras.getString("userName");
Toast.makeText(this, "尊敬的用户"+userName+",您的账号已验证成功!!!!!!!!!!!!!!!", Toast.LENGTH_SHORT).show();
}
}
.
项目直达下载通道为: Demo_MOB_SMS
如有问题请多指正,您的指正使我更正确的前行.