Android實現(xiàn)頁面短信驗證功能
本文實例為大家分享了Android實現(xiàn)頁面短信驗證功能的具體代碼,供大家參考,具體內(nèi)容如下
目標效果:
上一篇博文介紹的是使用SDK中自帶的驗證頁面,需要進行多次跳轉(zhuǎn),并且項目需要添加兩個框架,多有不便,這個例子簡化了短信驗證的代碼,但是不足的是功能不如原本那個完善。
1.新建項目,找到上一次下載的SDK文件中包含的SMSSDK項目,復制lib目錄下的三個jar包,res目錄下的raw文件夾和values目錄下的兩個xml文件到本項目。
2.activity_main.xml頁面設置布局。
activity_main.xml頁面:
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent" android:layout_height="match_parent" tools:context=".MainActivity" > <EditText android:id="@+id/etPhone" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_alignParentLeft="true" android:layout_alignParentRight="true" android:layout_alignParentTop="true" android:hint="請輸入手機號" android:layout_marginTop="45dp" android:ems="10" > <requestFocus /> </EditText> <EditText android:id="@+id/etNumber" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_alignParentLeft="true" android:layout_below="@+id/etPhone" android:hint="請輸入驗證碼" android:layout_marginTop="26dp" android:ems="10" /> <Button android:id="@+id/btGet" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_alignBottom="@+id/etNumber" android:layout_alignParentRight="true" android:text="獲取驗證碼" /> <Button android:id="@+id/btRegister" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_centerHorizontal="true" android:layout_centerVertical="true" android:text="注冊" /> </RelativeLayout>
3.MainActivity.java頁面驗證信息。
MainActivity.java頁面:
package com.example.notetest; import org.json.JSONObject; import com.example.notetest.MyCountDownTime; import android.app.Activity; import android.os.Bundle; import android.os.Handler; import android.os.Handler.Callback; import android.os.Message; import android.text.TextUtils; import android.view.View; import android.view.View.OnClickListener; import android.widget.Button; import android.widget.EditText; import android.widget.Toast; import cn.smssdk.EventHandler; import cn.smssdk.SMSSDK; import cn.smssdk.utils.SMSLog; public class MainActivity extends Activity implements OnClickListener, Callback { private static String APPKEY= "13e9653a7ff00"; // 填寫從短信SDK應用后臺注冊得到的APPSECRET private static String APPSECRET ="a881cac45bce10a59ccf22203062e763"; private EditText etPhone; private EditText etNumber; private Button btGet; private Button btRegister; private String phone; private MyCountDownTime myCountDownTime;// 用于驗證碼倒計時 private Handler mHandler;//用于執(zhí)行耗時操作 @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); SMSSDK.initSDK(this, APPKEY, APPSECRET, false); btGet = (Button) findViewById(R.id.btGet); btRegister = (Button) findViewById(R.id.btRegister); etPhone = (EditText) findViewById(R.id.etPhone); etNumber = (EditText) findViewById(R.id.etNumber); btGet.setOnClickListener(this); btRegister.setOnClickListener(this); initSDK(); } private void initSDK() { try { final Handler handler = new Handler(this); EventHandler eventHandler = new EventHandler() { 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); // 注冊短信回調(diào) } catch (Exception e) { e.printStackTrace(); } } @Override public void onClick(View v) { switch (v.getId()) { case R.id.btGet: phone = etPhone.getText().toString().trim(); if (!TextUtils.isEmpty(phone)) { SMSSDK.getVerificationCode("86", phone);// 獲取短信 getCode(); } else { Toast.makeText(MainActivity.this, "電話號碼不能為空", Toast.LENGTH_SHORT).show(); } break; case R.id.btRegister: String number = etNumber.getText().toString().trim(); if (!TextUtils.isEmpty(number)) { SMSSDK.submitVerificationCode("86", phone, number);// 驗證短信 } else { Toast.makeText(MainActivity.this, "驗證碼不能為空", Toast.LENGTH_SHORT) .show(); return; } break; default: break; } } private void getCode() { mHandler = new Handler(); mHandler.postDelayed(new Runnable() { @Override public void run() { startTimer(); } }, 2000); } /** * * @Description: TODO 發(fā)送成功后,開始倒計時 * */ private void startTimer() { if (null == myCountDownTime) { myCountDownTime = new MyCountDownTime(60000, 1000, btGet, "重新發(fā)送"); } myCountDownTime.start(); } /** * * @Description: TODO 一般發(fā)送失敗時,需要重置Button狀態(tài) */ private void cancelTimer(){ if(null != myCountDownTime){ myCountDownTime.cancel(); myCountDownTime.onFinish(); } } protected void onDestroy() { // 銷毀回調(diào)監(jiān)聽接口 SMSSDK.unregisterAllEventHandler(); super.onDestroy(); } @Override public boolean handleMessage(Message msg) { int event = msg.arg1; int result = msg.arg2; Object data = msg.obj; if (result == SMSSDK.RESULT_COMPLETE) { // 回調(diào)完成 if (event == SMSSDK.EVENT_SUBMIT_VERIFICATION_CODE) { // 提交驗證碼成功 Toast.makeText(MainActivity.this, "驗證成功", Toast.LENGTH_SHORT) .show(); } else if (event == SMSSDK.EVENT_GET_VERIFICATION_CODE) { // 獲取驗證碼成功 Toast.makeText(MainActivity.this, "獲取驗證碼成功", Toast.LENGTH_SHORT) .show(); } else if (event == SMSSDK.EVENT_GET_SUPPORTED_COUNTRIES) { // 返回支持發(fā)送驗證碼的國家列表 } } else { int status = 0; try { ((Throwable) data).printStackTrace(); Throwable throwable = (Throwable) data; JSONObject object = new JSONObject(throwable.getMessage()); String des = object.optString("detail"); status = object.optInt("status"); if (!TextUtils.isEmpty(des)) { Toast.makeText(MainActivity.this, des, Toast.LENGTH_SHORT) .show(); return false; } } catch (Exception e) { SMSLog.getInstance().w(e); } } return false; } }
4.新建MyCountDownTime.java頁面,用于獲取驗證碼后按鈕的倒計時。
MyCountDownTime.java頁面:
package com.example.notetest; import org.json.JSONObject; import com.example.notetest.MyCountDownTime; import android.app.Activity; import android.os.Bundle; import android.os.Handler; import android.os.Handler.Callback; import android.os.Message; import android.text.TextUtils; import android.view.View; import android.view.View.OnClickListener; import android.widget.Button; import android.widget.EditText; import android.widget.Toast; import cn.smssdk.EventHandler; import cn.smssdk.SMSSDK; import cn.smssdk.utils.SMSLog; public class MainActivity extends Activity implements OnClickListener, Callback { private static String APPKEY= "13e9653a7ff00"; // 填寫從短信SDK應用后臺注冊得到的APPSECRET private static String APPSECRET ="a881cac45bce10a59ccf22203062e763"; private EditText etPhone; private EditText etNumber; private Button btGet; private Button btRegister; private String phone; private MyCountDownTime myCountDownTime;// 用于驗證碼倒計時 private Handler mHandler;//用于執(zhí)行耗時操作 @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); SMSSDK.initSDK(this, APPKEY, APPSECRET, false); btGet = (Button) findViewById(R.id.btGet); btRegister = (Button) findViewById(R.id.btRegister); etPhone = (EditText) findViewById(R.id.etPhone); etNumber = (EditText) findViewById(R.id.etNumber); btGet.setOnClickListener(this); btRegister.setOnClickListener(this); initSDK(); } private void initSDK() { try { final Handler handler = new Handler(this); EventHandler eventHandler = new EventHandler() { 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); // 注冊短信回調(diào) } catch (Exception e) { e.printStackTrace(); } } @Override public void onClick(View v) { switch (v.getId()) { case R.id.btGet: phone = etPhone.getText().toString().trim(); if (!TextUtils.isEmpty(phone)) { SMSSDK.getVerificationCode("86", phone);// 獲取短信 getCode(); } else { Toast.makeText(MainActivity.this, "電話號碼不能為空", Toast.LENGTH_SHORT).show(); } break; case R.id.btRegister: String number = etNumber.getText().toString().trim(); if (!TextUtils.isEmpty(number)) { SMSSDK.submitVerificationCode("86", phone, number);// 驗證短信 } else { Toast.makeText(MainActivity.this, "驗證碼不能為空", Toast.LENGTH_SHORT) .show(); return; } break; default: break; } } private void getCode() { mHandler = new Handler(); mHandler.postDelayed(new Runnable() { @Override public void run() { startTimer(); } }, 2000); } /** * * @Description: TODO 發(fā)送成功后,開始倒計時 * */ private void startTimer() { if (null == myCountDownTime) { myCountDownTime = new MyCountDownTime(60000, 1000, btGet, "重新發(fā)送"); } myCountDownTime.start(); } /** * * @Description: TODO 一般發(fā)送失敗時,需要重置Button狀態(tài) */ private void cancelTimer(){ if(null != myCountDownTime){ myCountDownTime.cancel(); myCountDownTime.onFinish(); } } protected void onDestroy() { // 銷毀回調(diào)監(jiān)聽接口 SMSSDK.unregisterAllEventHandler(); super.onDestroy(); } @Override public boolean handleMessage(Message msg) { int event = msg.arg1; int result = msg.arg2; Object data = msg.obj; if (result == SMSSDK.RESULT_COMPLETE) { // 回調(diào)完成 if (event == SMSSDK.EVENT_SUBMIT_VERIFICATION_CODE) { // 提交驗證碼成功 Toast.makeText(MainActivity.this, "驗證成功", Toast.LENGTH_SHORT) .show(); } else if (event == SMSSDK.EVENT_GET_VERIFICATION_CODE) { // 獲取驗證碼成功 Toast.makeText(MainActivity.this, "獲取驗證碼成功", Toast.LENGTH_SHORT) .show(); } else if (event == SMSSDK.EVENT_GET_SUPPORTED_COUNTRIES) { // 返回支持發(fā)送驗證碼的國家列表 } } else { int status = 0; try { ((Throwable) data).printStackTrace(); Throwable throwable = (Throwable) data; JSONObject object = new JSONObject(throwable.getMessage()); String des = object.optString("detail"); status = object.optInt("status"); if (!TextUtils.isEmpty(des)) { Toast.makeText(MainActivity.this, des, Toast.LENGTH_SHORT) .show(); return false; } } catch (Exception e) { SMSLog.getInstance().w(e); } } return false; } }
5.運行就可以顯示目標效果了。
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
Android仿微信圖片上傳帶加號且超過最大數(shù)隱藏功能
這篇文章給大家分享android仿照微信空間上傳圖片,顯示圖片數(shù)量以及超過最大,上傳按鈕隱藏功能,非常不錯,具有參考借鑒價值,需要的朋友參考下吧2018-03-03Android UI實現(xiàn)單行文本水平觸摸滑動效果
這篇文章主要為大家詳細介紹了Android UI實現(xiàn)單行文本水平觸摸滑動效果,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2016-10-10Android開發(fā)實現(xiàn)生成excel的方法詳解
這篇文章主要介紹了Android開發(fā)實現(xiàn)生成excel的方法,結合實例形式詳細分析了Android生成Excel的具體步驟與存儲、導入、添加等相關操作技巧,需要的朋友可以參考下2017-10-10解決Android Studio一直停留在MyApplication:syncing的問題
這篇文章主要介紹了Android Studio一直停留在MyApplication:syncing的完美解決方案,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-10-10Android實現(xiàn)微信朋友圈發(fā)本地視頻功能
這篇文章主要介紹了Android實現(xiàn)微信朋友圈發(fā)本地視頻功能的相關資料,非常不錯,具有參考借鑒價值,需要的朋友可以參考下2016-11-11