相信有不少朋友在作三方登錄的時候會加入短信驗證的功能,最近恰好被分配安排實現這一需求,本人新手一枚,特意去網上搜了資料,目前用的比較多的大漢、雲通信還有MobTech的SMSSDK。對比之下,最終選擇了徹底免費的SMSSDK打算小試牛刀。一下是我的在使用SDK過程當中的一些心得,但願各位大神走過路過給點建議,喜歡的給個當心心就好。 首先進入MobTech官網(www.mob.com/)直接找到文檔介紹,做爲第一次使用的人來講操做很簡單,至於使用方法就不贅述了,裏面介紹仍是比較詳細的。整個文檔瀏覽了一遍,介紹了2種方法:一種as的maven集成,一種eclipse的普通集成。由於公司的項目的是as的,後者就不考慮了,maven集成的方式講真簡直太適合新手了,只要在gradle配置下就OK了,省心省力,先貼上代碼:android
將下面的腳本添加到您的根模塊build.gradle中:app
buildscript {
// 添加MobSDK的maven地址
repositories {
maven {
url "http://mvn.mob.com/android"
}
}
dependencies {
// 註冊MobSDK
classpath "com.mob.sdk:MobSDK:+"
}
複製代碼
} 在app下的build.gradle中,添加MobSDK插件和擴展,如: // 添加插件 apply plugin: "com.mob.sdk" // 在MobSDK的擴展中註冊SMSSDK的相關信息 MobSDK { appKey "d580ad56****" appSecret "7fcae59a62342e7e2759e9e397**" SMSSDK {}eclipse
}
複製代碼
//這裏的appkey跟appsecret是在mob後臺建立應用時獲取的,因此須要使用時先去官網註冊下帳號,進入後臺建立。 配置完以上gradle配置後,基本算是集成完SMSSDK了,文檔中提供了調用的代碼,直接複製粘貼進個人demo測試了下,出乎意料的順利,可是惟一不滿的就是這個短信驗證界面太老套了,產品那邊必定過不去,(收起偷懶的心思),默默又去研究了一遍文檔,看到了有個無gui的使用方法。(wiki.mob.com/sms-android…),他們提供了相關的接口,具體就不貼圖啦,你們能夠去官網文檔看下。須要注意的是,若是是本身的ui的話須要在以前gradle配置SMSSDK的地方加上 SMSSDK{ gui falsemaven
}
複製代碼
由於只是demo測試,ui佈局隨便寫的,僅僅爲了知足正常的測試,樣子醜醜的~ide
下面就是寫接口代碼的調用了,文檔提供了初始化的接口,registerEventHandler用來往SMSSDK中註冊一個事件接收器,SMSSDK容許開發者註冊任意數量的接收器,全部接收器都會在事件 被觸發時收到消息,如下是個人部分代碼:佈局
EventHandler handler = new EventHandler(){
@Override
public void afterEvent(int event, int result, Object data) {
if (result == SMSSDK.RESULT_COMPLETE){
//回調完成
if (event == SMSSDK.EVENT_SUBMIT_VERIFICATION_CODE) {
//提交驗證碼成功
runOnUiThread(new Runnable() {
@Override
public void run() {
Toast.makeText(MainActivity.this,"驗證成功",Toast.LENGTH_SHORT).show();
}
});
}else if (event == SMSSDK.EVENT_GET_VOICE_VERIFICATION_CODE){
runOnUiThread(new Runnable() {
@Override
public void run() {
Toast.makeText(MainActivity.this,"語音驗證發送",Toast.LENGTH_SHORT).show();
}
});
}
else if (event == SMSSDK.EVENT_GET_VERIFICATION_CODE){
//獲取驗證碼成功
runOnUiThread(new Runnable() {
@Override
public void run() {
Toast.makeText(MainActivity.this,"驗證碼已發送",Toast.LENGTH_SHORT).show();
}
});
}else if (event == SMSSDK.EVENT_GET_SUPPORTED_COUNTRIES){
Log.i("test","test");
}
}else{
((Throwable)data).printStackTrace();
Throwable throwable = (Throwable) data;
throwable.printStackTrace();
Log.i("1234",throwable.toString());
try {
JSONObject obj = new JSONObject(throwable.getMessage());
final String des = obj.optString("detail");
if (!TextUtils.isEmpty(des)){
runOnUiThread(new Runnable() {
@Override
public void run() {
Toast.makeText(MainActivity.this,des,Toast.LENGTH_SHORT).show();
}
});
}
} catch (JSONException e) {
e.printStackTrace();
}
}
}
};
SMSSDK.registerEventHandler(handler);
複製代碼
後面就是簡單的發送驗證等接口調用: findViewById(R.id.tv_test1).setOnClickListener(new View.OnClickListener() { @Override public void onClick(View view) { phone = etVGetcode.getText().toString(); //獲取驗證碼 if (TextUtils.isEmpty(phone)) Toast.makeText(MainActivity.this,"號碼不能爲空",Toast.LENGTH_SHORT).show(); Log.i("1234",phone.toString()); SMSSDK.getVerificationCode("86",phone,null); } }); findViewById(R.id.tv_test_vcode_valiable).setOnClickListener(new View.OnClickListener() { @Override public void onClick(View view) { //提交驗證碼驗證 if (TextUtils.isEmpty(phone)) Toast.makeText(MainActivity.this,"號碼不能爲空",Toast.LENGTH_SHORT).show(); number = etVCode.getText().toString(); if (TextUtils.isEmpty(number)) Toast.makeText(MainActivity.this,"號碼不能爲空",Toast.LENGTH_SHORT).show(); Log.i("1234",phone+","+number); SMSSDK.submitVerificationCode("86",phone,number); } });測試
代碼其實仍是比較簡單的,測試最重要的驗證效率,我的感受挺快的,基本發送後兩三秒就收到了,更重要的是免費,免費,免費的啊。重要的事情說三遍。因此說仍是值得推薦的,說了那麼多看下效果圖:gradle
補充說明一個坑:ui
這裏是mob後臺添加短信產品設置的地方,那會兒手賤不當心誤點開了,致使一直收不到短信,搞了半天仍是問技術客服才知道的,各位老哥務比慎點。。 寫的比較粗糙,但願對須要的同窗有幫助哈=。=有不足和錯誤之處還請你們多多指正啦~this