Android开发之短信验证码示例

在说Android中的短信验证码这个知识点前,我们首先来了解下聚合数据

聚合数据介绍
聚合数据是一家国内最大的基础数据API提供商,专业从事互联网数据服务。免费提供从天气查询、空气质量、地图坐标到金融基金、电商比价、违章查询等各个领域的安全、稳定和高效的数据。开发者可以免费试用聚合数据API进行移动APP的快速开发,免除数据收集、维护等环节,大大降低开发周期及成本。因此我们可以采用聚合数据给我提供好的一套东西来进行短信验证码的功能的添加。

第一步,注册聚合数据
进入聚合数据官网(https://www.juhe.cn/)注册一个账号,完成注册后进入,"个人中心"——>“我的数据”点击申请数据如下图所示:

Paste_Image.png

第二步,申请Appkey
申请后你会得到一个Appkey,此Appkey非常重要。

第三步,下载SDK
下载地址:https://www.juhe.cn/juhesdk

第四步,创建工程,配置环境
1.创建一个工程把我们下载的SDK里libs下的“armeabi文件”和"smscaptcha_v_1_4.jar"复制到我们工程的libs目录下
2.在AndroidManifest中添加开发密钥、所需权限等信息
(1)在application中添加开发密钥

<meta-data    
      android:name="JUHE_KEY"    
      android:value="开发者 key" />

(2)添加所需权限

<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />    
<uses-permission android:name="android.permission.INTERNET" />    
<uses-permission android:name="android.permission.ACCESS_WIFI_STATE" />    
<uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION " />    
<uses-permission android:name="android.permission.READ_FINE_LOCATION" />  
<uses-permission android:name="android.permission.READ_PHONE_STATE" />  
<uses-permission android:name="android.permission.READ_CONTACTS" /> 

(3)在应用程序创建时初始化 SDK引用的Context全局变量
在这一步我们有两种方法
第一种在Activity中配置

public class MainActivity extends Activity {    
    @Override    
    protected void onCreate(Bundle savedInstanceState) {    
        super.onCreate(savedInstanceState);     
        //在使用SDK各组件之前初始化context信息,传入ApplicationContext    
        //注意该方法要再setContentView方法之前实现    
    /**  
    * 初始化方法 
    * @param context 
    * @needFriends 是否需要好友功能 
    */   
        CommonFun.initialize(getApplicationContext(),true);    
        setContentView(R.layout.activity_main);    
    }    
} 

下面这个注意是聚合数据文档给我们的建议,它建议我们把这个初始化工作放在Application中,因为程序运行首先会运行Application中的方法
注意:在SDK各功能组件使用之前都需要调用CommonFun.initialize(getApplicationContext(),true);,因此我们建议该方法放在Application的初始化方法中
所以我们就按它建议的方法,而不采用第一种方法这样我们需要创建一个Applicaiton类MyApplication如下

package com.example.android.sms;  
  
import com.thinkland.sdk.util.CommonFun;  
  
import android.app.Application;  
  
public class MyApplication extends Application {  
  
    @Override  
    public void onCreate() {  
        super.onCreate();  
        CommonFun.initialize(getApplicationContext(), false);   
    }  
}

声明好Application后不要忘了在清单文件中配置


好了环境已经配置好了,我们来验证一下看看我们是否能收到短信
MainActivity的代码如下

package com.example.android.sms;  
  
import com.thinkland.sdk.sms.SMSCaptcha;  
import com.thinkland.sdk.util.BaseData;  
import com.thinkland.sdk.util.CommonFun;  
  
import android.os.Bundle;  
import android.app.Activity;  
import android.util.Log;  
import android.view.Menu;  
import android.widget.Toast;  
  
public class MainActivity extends Activity {  
  
    protected static final String TAG ="MainActivity";  
  
    @Override  
    protected void onCreate(Bundle savedInstanceState) {  
        super.onCreate(savedInstanceState);  
      
        setContentView(R.layout.activity_main);  
        //初始化 SMSCaptcha对象在这个对象中有给我们发送短信验证码的方法  
        SMSCaptcha smsCaptcha=SMSCaptcha.getInstance();  
        //调用发送短信验证码的方法,在其中有一个回调  
          
        /** 
          phone 手机号码 
          callBack  返回结果回调方法. 
         */  
        smsCaptcha.sendCaptcha("此处输入你的手机号",new BaseData.ResultCallBack() {  
              
            @Override  
            public void onResult(int code, String reason, String result) {  
                  
                   /* 
                    code:返回码: 
                    服务器: 0 成功; 1 错误; 
                    本地: -2 本地网络异常; -3 服务器网络异常;-4 解析错误;-5初始化异常 
                    reason:返回信息 成功或错误原因. 
                    result:返回结果,JSON格式.错误或者无返回值时为空.*/  
                  
                if(code==0){  
                    Log.i(TAG,"code="+code);  
                    Log.i(TAG,"reason="+reason);  
                    Log.i(TAG,"result="+result);  
                }  
            }  
        });  
    }  
}        

返回结果如下:



第五步:完整的功能的实现,以及界面UI的实现
首先我们来看下界面第一个界面



我们在这个界面输入手机号,及短信的目的地,点击下一步后会弹出一个Dialog

点击确定后会调用会调用聚合数据给我们提供的sendCaptcha方法

    /*点击确定后调用sendCaptcha方法向服务器提交手机号码 
                  code(返回码):  
                  服务器:0 成功,1 错误;  
                  本  地:-2 本地网络异常,-3 服务器网络异常,-4 解析错误,-5 初始化异常。  
                  reason(返回信息):成功或错误的原因。  
                  result(返回结果):JSON格式,错误或者无返回值时为空。  
                */   
smsCaptcha.sendCaptcha(phone,new ResultCallBack() {  
                      
@Override  
public void onResult(int code, String reason, String result) {  
closeDialog();  
if(code==0){  
afterCapterRequested();  
}                         
  }  
  
);  

当返回的code==0时说明短信验证码发送成功,我们需要进行界面的跳转,代码如下

//当code=0成功时,跳转到输入验证码的Activity  
    private void afterCapterRequested() {  
        String phone=etPhoneNumber.getText().toString().trim().replaceAll("\\ss*",   
                "");  
        String code=tvCountryNumber.getText().toString().trim();  
        String fomatedPhone=code+" "+splitPhoneNum(phone);  
          
        Toast.makeText(this,"成功",Toast.LENGTH_SHORT).show();  
        Intent intent=new Intent();  
        intent.setClass(RegistActivity.this,CaptchaActivity.class);  
        //把手机号码和格式化的手机号码传过去  
        intent.putExtra("formatedPhone",fomatedPhone);  
        intent.putExtra("phone",phone);  
        startActivity(intent);  
    }  
      
    //格式化手机号码的方法,格式化后的形式:+86 131 4118 2951  
    private String splitPhoneNum(String phone) {  
          
        StringBuilder builder=new StringBuilder(phone);  
        builder.reverse();  
        for(int i=4,len=builder.length();i<len;i+=5){  
            builder.insert(i,' ');  
        }  
        builder.reverse();  
        return builder.toString();  
    } 

跳转的界面的布局如下



在这个界面我们需要输入短信验证码,输入短信验证码后点击下一步时会调用聚合数据的commitCaptcha这个方法,比对数据的方法,

smsCaptcha.commitCaptcha(phoneNumbber,verfiyCode,new ResultCallBack() {  
        /*  
                    code:返回码:  
                    服务器: 0 成功; 1 错误;  
                    本地: -2 本地网络异常; -3 服务器网络异常;-4 解析错误;-5初始化异常  
                    reason:返回信息 成功或错误原因.  
                    result:返回结果,JSON格式.错误或者无返回值时为空.*/   
        @Override  
        public void onResult(int code,String reason,String result) {  
        if(code==0){  
        Log.i(TAG,code+"");  
        Log.i(TAG,reason);  
        Log.i(TAG,result);  
        Toast.makeText(CaptchaActivity.this,"您输入的验证码正确",Toast.LENGTH_SHORT).show();  
        CaptchaActivity.this.finish();  
        }else{  
        Toast.makeText(CaptchaActivity.this,"您输入的验证码不正确",Toast.LENGTH_SHORT).show();  
                }  
            }  
        });   

我们可以看到这个方法所需的参数是①手机号码②手机验证码,我们调用此方法后聚合数据的服务器会进行判断,此验证码是否是刚才发送给这个手机号的验证码,验证后给我返回结果,我们根据返回的结果就可以进行相应的操作。
在上面的界面中我们发现有一个倒计时的功能,我在这里说一下思路,当然这个倒计时方法有很多。在这个Demo中倒计时是放在一个tvCountDown的一个textView中,首先

//R.string.receiveMessgeCountDown的内容为:<Data>接收短信大约需要<font color=#209526>%s</font>秒</Data>  
//这句话就是用time把 html里的%号替换掉  
String unReceive=getResources().getString(R.string. receiveMessgeCountDown,time );  
//把用html格式化的字符串设置给倒计时的文本框  
tvCountDown.setText(Html.fromHtml(unReceive));  

这样我们可以把html格式化的文本填充到tvCountDown中。接下来就是倒计时的方法了

private final int RETRY_INTERVAL =60;  
private int time=RETRY_INTERVAL;  
     //倒计时方法  
     private void countDown() {  
            new Thread( new Runnable() {  
                  
                 @Override  
                 public void run() {  
                 while( time-->0){  
               //减一后的time把<Data>接收短信大约需要<font color=#209526>%s</font>秒</Data>中的%号替换掉  
                String countDownTime=CaptchaActivity.this .getResources().getString(R.string. receiveMessgeCountDown,time );  
              //在主线程上更新tvCountDown  
              upDateTvCountDown(countDownTime);  
              try {  
                 Thread. sleep(1000);  
                  } catch (InterruptedException e) {  
                      e.printStackTrace();  
                     }  
                 }     
                String countDownTime=CaptchaActivity.this .getResources().getString(R.string. unreceiveMessage, time);  
               upDateTvCountDown(countDownTime);  
               time = RETRY_INTERVAL;  
           }  
     }).start();  
}  
//在主线程上更新tvCountDown  
private void upDateTvCountDown(final String countDownTime) {  
           runOnUiThread( new Runnable() {  
                 @Override  
                 public void run() {  
                  tvCountDown.setText(Html. fromHtml(countDownTime));  
                  tvCountDown.setEnabled( false);  
                }  
           });  
     }  

总结:其实使用聚合数据的短信验证码功能,主要就两个方法,一个是获取验证码的方法sendCaptcha,一个是提交验证码进行验证的方法commitCaptcha。我们在此基础上,可以根据需求对界面进行更改。以上就是对短信验证码的主要逻辑进行的介绍。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,504评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,434评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,089评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,378评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,472评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,506评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,519评论 3 413
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,292评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,738评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,022评论 2 329
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,194评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,873评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,536评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,162评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,413评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,075评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,080评论 2 352

推荐阅读更多精彩内容