Android实现页面短信验证功能
作者:Vivinia_Vivinia 发布时间:2022-02-13 01:36:56
标签:Android,短信验证
本文实例为大家分享了Android实现页面短信验证功能的具体代码,供大家参考,具体内容如下
目标效果:
上一篇博文介绍的是使用SDK中自带的验证页面,需要进行多次跳转,并且项目需要添加两个框架,多有不便,这个例子简化了短信验证的代码,但是不足的是功能不如原本那个完善。
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;//用于执行耗时操作
@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); // 注册短信回调
} 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 发送成功后,开始倒计时
*
*/
private void startTimer() {
if (null == myCountDownTime) {
myCountDownTime = new MyCountDownTime(60000, 1000, btGet, "重新发送");
}
myCountDownTime.start();
}
/**
*
* @Description: TODO 一般发送失败时,需要重置Button状态
*/
private void cancelTimer(){
if(null != myCountDownTime){
myCountDownTime.cancel();
myCountDownTime.onFinish();
}
}
protected void onDestroy() {
// 销毁回调监听接口
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) {
// 回调完成
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) {
// 返回支持发送验证码的国家列表
}
} 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;//用于执行耗时操作
@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); // 注册短信回调
} 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 发送成功后,开始倒计时
*
*/
private void startTimer() {
if (null == myCountDownTime) {
myCountDownTime = new MyCountDownTime(60000, 1000, btGet, "重新发送");
}
myCountDownTime.start();
}
/**
*
* @Description: TODO 一般发送失败时,需要重置Button状态
*/
private void cancelTimer(){
if(null != myCountDownTime){
myCountDownTime.cancel();
myCountDownTime.onFinish();
}
}
protected void onDestroy() {
// 销毁回调监听接口
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) {
// 回调完成
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) {
// 返回支持发送验证码的国家列表
}
} 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.运行就可以显示目标效果了。
来源:https://blog.csdn.net/hester_hester/article/details/51719821


猜你喜欢
- 目录一、前言二、JMH概述1、什么是JMH2、JMH适用的典型场景3、JMH基本概念三、JMH的使用1、快速跑起来2、JMH常用注解详细介绍
- google benchmark已经为我们提供了类似的功能,而且使用相当简单。具体的解释在后面,我们先来看几个例子,我们人为制造几个时间复杂
- 0、引言在开发的过程中,很多业务场景需要一个树形结构的结果集进行前端展示,也可以理解为是一个无限父子结构,常见的有报表指标结构、菜单结构等。
- 关于《JavaCV的摄像头实战》系列《JavaCV的摄像头实战》顾名思义,是使用JavaCV框架对摄像头进行各种处理的实战集合,这是欣宸作为
- 资源加载器使用Java,您可以使用当前线程的classLoader并尝试加载文件,但是Spring Framework为您提供了更为优雅的解
- 本文实例为大家分享了C#实现猜数字游戏具体代码,供大家参考,具体内容如下给定一个0-100的随机数字猜其大小题目样式:电脑产生一个0到100
- 前言现如今几乎大多数Java应用,例如我们耳熟能详的tomcat, struts2, netty...等等数都数不过来的软件,要满足通用性,
- 本文实例为大家分享了OpenGL绘制贝塞尔曲线的具体代码,供大家参考,具体内容如下最终效果图:通过3个点形成一条贝塞尔曲线1. 鼠标问题在使
- Map集合的概述概述:interface Map<K,V> 其中K是键的类型,键是唯一的,不重复。V是值的类型,是可以重复。且每
- 关于隐藏和覆盖的区别,要提到RTTI(run-time type identification)(运行期类型检查),也就是运行期的多态,当一
- --删除外键 语法:alter table 表名 drop constraint 外键约束名 如: alter table Stu_PkFk
- 前言上一篇做了一个滑动折叠的Header控件,主要就是练习了一下滑动事件冲突的问题,控件和文章写的都不怎么样。本来想通过这篇文章的控件,整合
- 本文实例为大家分享了Android实现手机多点触摸画圆的具体代码,供大家参考,具体内容如下静态效果图:(多个手指按下和抬起的状态)代码实现部
- 序列化和反序列化的概念当我们在Java中创建对象的时候,对象会一直存在,直到程序终止时。但有时候可能存在一种"持久化"场
- 一、增删改1、增加<!-- 添加用户--><insert id="saveUser" paramete
- 熟悉Eclipse的都知道Eclipse经常性的会出现一些莫名其妙的问题,有时候运行的好好的突然重启一下项目就莫名的报错,所以经常会用到cl
- SpringBoot项目当中支持的三类配置文件:application.propertiesapplication.ymlapplicati
- Android DownloadProvider 源码分析:Download的源码编译分为两个部分,一个是DownloadProvider.
- 本文主要给大家分享如何在全局上去监听 click 点击事件,并做些通用处理或是拦截。使用场景可能就是具体的全局防快速重复点击,或是通用打点分
- 1 前言许多语言,例如 Perl ,Python 和 Ruby ,都有集合的本地支持。有些语言(例如Python)甚至将基本集合组件(列表,