最近突然想起App里面的登錄模塊,有可以使用手機(jī)號碼注冊的功能,感覺此功能在大多款A(yù)pp里面都比較常見,因此在此做一個記錄,順便將之前踩過得坑在此記錄一下,之前一直沒有在簡書上面寫過文章,感覺慌慌噠。好了,下面開始記錄下我的過程。
先放上最終的效果圖:

我去,這上傳的效果也不是太好,各位看官請見諒,不過基本的功能還是有了的,不妨礙后面的閱讀。
下面我將一步步介紹如何實現(xiàn)這個功能的。
下面開始上代碼
package com.rain.messageandsend;import android.os.CountDownTimer;import android.support.v7.app.AppCompatActivity;import android.os.Bundle;import android.text.TextUtils;import android.view.View;import android.widget.Button;import android.widget.EditText;import android.widget.Toast;import com.cloopen.rest.sdk.CCPRestSmsSDK;import java.util.HashMap;import java.util.Random;import java.util.Set;public class MainActivity extends AppCompatActivity { private Button mBt_message; private EditText mEt_number; private String mNumber; private MyCountDown mCountDown;@Overrideprotected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); initView(); long time = Timeutils.getTime(this, "time"); //更新時間ui if(time==0){ time = 60000; mCountDown = new MyCountDown(mBt_message,time,1000); }else{ mCountDown = new MyCountDown(mBt_message,time,1000); mCountDown.start(); }}private void initView() { mBt_message = (Button) findViewById(R.id.bt_number); mEt_number = (EditText) findViewById(R.id.et_number);}//獲取驗證碼public void click01(View view){ getMessageNumber(); Toast.makeText(this, "點擊了獲取驗證碼", Toast.LENGTH_SHORT).show(); mCountDown.start();}//通過這個方法獲取驗證碼的private void getMessageNumber() { HashMap<String, Object> result = null; //初始化SDK CCPRestSmsSDK restAPI = new CCPRestSmsSDK(); //******************************注釋********************************************* //*初始化服務(wù)器地址和端口 * //*沙盒環(huán)境(用于應(yīng)用開發(fā)調(diào)試):restAPI.init("sandboxapp.cloopen.com", "8883");* //*生產(chǎn)環(huán)境(用戶應(yīng)用上線使用):restAPI.init("app.cloopen.com", "8883"); * //******************************************************************************* restAPI.init("sandboxapp.cloopen.com", "8883"); //******************************注釋********************************************* //*初始化主帳號和主帳號令牌,對應(yīng)官網(wǎng)開發(fā)者主賬號下的ACCOUNT SID和AUTH TOKEN * //*ACOUNT SID和AUTH TOKEN在登陸官網(wǎng)后,在“應(yīng)用-管理控制臺”中查看開發(fā)者主賬號獲取* //*參數(shù)順序:第一個參數(shù)是ACOUNT SID,第二個參數(shù)是AUTH TOKEN。 * //******************************************************************************* restAPI.setAccount("", ""); //******************************注釋********************************************* //*初始化應(yīng)用ID * //*測試開發(fā)可使用“測試Demo”的APP ID,正式上線需要使用自己創(chuàng)建的應(yīng)用的App ID * //*應(yīng)用ID的獲取:登陸官網(wǎng),在“應(yīng)用-應(yīng)用列表”,點擊應(yīng)用名稱,看應(yīng)用詳情獲取APP ID* //******************************************************************************* restAPI.setAppId(""); //******************************注釋**************************************************************** //*調(diào)用發(fā)送模板短信的接口發(fā)送短信 * //*參數(shù)順序說明: * //*第一個參數(shù):是要發(fā)送的手機(jī)號碼,可以用逗號分隔,一次最多支持100個手機(jī)號 * //*第二個參數(shù):是模板ID,在平臺上創(chuàng)建的短信模板的ID值;測試的時候可以使用系統(tǒng)的默認(rèn)模板,id為1。 * //*系統(tǒng)默認(rèn)模板的內(nèi)容為“【云通訊】您使用的是云通訊短信模板,您的驗證碼是{1},請于{2}分鐘內(nèi)正確輸入”* //*第三個參數(shù)是要替換的內(nèi)容數(shù)組。 * //************************************************************************************************** //**************************************舉例說明*********************************************************************** //*假設(shè)您用測試Demo的APP ID,則需使用默認(rèn)模板ID 1,發(fā)送手機(jī)號是13800000000,傳入?yún)?shù)為6532和5,則調(diào)用方式為 * //*result = restAPI.sendTemplateSMS("13800000000","1" ,new String[]{"6532","5"}); * //*則13800000000手機(jī)號收到的短信內(nèi)容是:【云通訊】您使用的是云通訊短信模板,您的驗證碼是6532,請于5分鐘內(nèi)正確輸入 * //********************************************************************************************************************* //四位的隨機(jī)數(shù) mNumber = (new Random().nextInt(8999) + 1000) + ""; result = restAPI.sendTemplateSMS("此處為手機(jī)號碼","1" ,new String[]{mNumber,"5"}); System.out.println("SDKTestGetSubAccounts result=" + result); if("000000".equals(result.get("statusCode"))){ //正常返回輸出data包體信息(map) HashMap<String,Object> data = (HashMap<String, Object>) result.get("data"); Set<String> keySet = data.keySet(); for(String key:keySet){ Object object = data.get(key); System.out.println(key +" = "+object); } }else{ //異常返回輸出錯誤碼和錯誤信息 System.out.println("錯誤碼=" + result.get("statusCode") +" 錯誤信息= "+result.get("statusMsg")); }}//驗證驗證碼public void click02(View view){ String infoNumber = mEt_number.getText().toString(); if(TextUtils.isEmpty(infoNumber)){ Toast.makeText(this, "驗證碼不能為空", Toast.LENGTH_SHORT).show(); }else{ if(infoNumber.equals(mNumber)){ Toast.makeText(this, "驗證碼正確", Toast.LENGTH_SHORT).show(); }else{ Toast.makeText(this, "驗證碼錯誤", Toast.LENGTH_SHORT).show(); } }}/** * 繼承 CountDownTimer * * 重寫 父類的方法 onTick() 、 onFinish() */class MyCountDown extends CountDownTimer{ private Button bt; /** * @param millisInFuture The number of millis in the future from the call * to {@link #start()} until the countdown is done and {@link #onFinish()} * is called. * 表示以毫秒為單位 倒計時的總數(shù) * * 例如 millisInFuture=1000 表示1秒 * @param countDownInterval The interval along the way to receive * {@link #onTick(long)} callbacks. * 表示 間隔 多少微秒 調(diào)用一次 onTick 方法 * * 例如: countDownInterval =1000 ; 表示每1000毫秒調(diào)用一次onTick() */ public MyCountDown(Button button,long millisInFuture, long countDownInterval) { super(millisInFuture, countDownInterval); this.bt = button; } @Override public void onTick(long millisUntilFinished) { bt.setText((millisUntilFinished / 1000) + "秒后可重發(fā)"); bt.setClickable(false); Timeutils.saveTime(MainActivity.this,"time",millisUntilFinished); } @Override public void onFinish() { bt.setClickable(true); bt.setText("獲取驗證碼"); } }}下面是工具類
package com.rain.messageandsend;import android.content.Context;import android.content.SharedPreferences;/** * Created by rain on 2017/8/8 0008. */public class Timeutils { private static SharedPreferences sSp; public static void saveTime(Context context, String name, long time){ if(sSp == null){ sSp = context.getSharedPreferences("ccc", Context.MODE_PRIVATE); } sSp.edit().putLong(name,time).apply();}public static long getTime(Context context, String name){ if(sSp == null){ sSp = context.getSharedPreferences("ccc", Context.MODE_PRIVATE); } return sSp.getLong(name,0L); }}布局:
<?xml version="1.0" encoding="utf-8"?><LinearLayoutxmlns:android="http://schemas.android.com/apk/res/android"android:id="@+id/activity_main"android:orientation="vertical"android:paddingBottom="16dp"android:paddingRight="16dp"android:paddingTop="16dp"android:paddingLeft="16dp"android:layout_width="match_parent"android:layout_height="match_parent"><LinearLayout android:layout_gravity="center_vertical" android:layout_width="match_parent" android:layout_height="wrap_content"> <EditText android:layout_weight="2" android:layout_width="0dp" android:hint="請輸入驗證碼" android:id="@+id/et_number" android:layout_height="wrap_content"/> <Button android:onClick="click01" android:gravity="center" android:id="@+id/bt_number" android:layout_gravity="center_vertical" android:layout_width="0dp" android:text="獲取驗證碼" android:layout_weight="1" android:layout_height="wrap_content"/></LinearLayout><Button android:onClick="click02" android:layout_marginTop="16dp" android:gravity="center" android:layout_width="match_parent" android:text="驗證" android:layout_height="wrap_content"/></LinearLayout>
其中在計時器方面我使用了谷歌封裝的一個類 CountDownTimer 這個類完美的進(jìn)行了一些封裝,并且提供回調(diào)給我們使用。之前我是直接使用的最原始的方法使用的,自己寫線程以及控制按鈕的點擊狀態(tài)等等。
該demo最典型的是當(dāng)我們的App完全退出后,再次點擊進(jìn)來里面的倒計時開始時間不是上次退出的時間,而是從上次退出后,依然在進(jìn)行倒計時功能。看到這里,相信您一定已經(jīng)了解了大概原理了,該案例不建議大家直接拿到項目中去用,可能還會有一些我沒有檢測到的bug。該文章是我第一次在簡書這個平臺上面寫,可能會存在各方面的問題,難免經(jīng)驗不足,希望大家不要在意。另外如果能夠幫助到大家,那就更好不過了。
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持VEVB武林網(wǎng)。
新聞熱點
疑難解答
圖片精選