相信有不少朋友在作三方登錄的時候會加入短信驗證的功能,最近恰好被分配安排實現這一需求,本人新手一枚,特意去網上搜了資料,目前用的比較多的大漢.雲通信還有MOB的smssdk,對比之下,最終選擇了徹底免費的MOB產品試試手,下面就是我在使用sdk過程當中一些心得,但願看到的大神給點建議,喜歡的給個當心心就好。java
首先我上網百度了下Mob的官網(http://www.mob.com/)做爲第一次使用習慣性的先打開文檔介紹,關於使用方法這裏介紹的算是比較詳細的,我這裏也不作贅述了,整個文檔瀏覽了一遍,介紹說是兩種方法,一種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 {} }
//這裏的appkey跟appsecret是在mob後臺建立應用時獲取的,因此須要使用時先去官網註冊下帳號,進入後臺建立 eclipse
配置完以上gradle配置後,基本算是集成完smssdk了,文檔中提供了調用的代碼,直接複製粘貼進個人demo測試了下,出乎意料的順利,可是惟一不滿的就是這個短信驗證界面太老套了,產品那邊必定過不去,(收起偷懶的心思),默默又去研究了一遍文檔,看到了有個無gui的使用方法(http://wiki.mob.com/sms-android-%E6%97%A0gui%E6%8E%A5%E5%8F%A3%E8%B0%83%E7%94%A8/),他們提供了相關的接口,具體的我就不貼圖了,你們能夠去官網文檔看下,須要注意的是,若是是本身的ui的話須要在以前gradle配置smssdk的地方加上maven
SMSSDK{ gui false }
由於只是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後臺添加短信產品設置的地方,那會兒手賤不當心誤點開了,致使一直收不到短信,搞了半天仍是問技術客服才知道的,各位老哥務比慎點。。
寫的比較粗糙,但願對須要的同窗有幫助哈=。=