一直想自己做点小玩意,有希望能够用户参与进来,于是乎就怎么都避不开注册登录这个环节,人呢,比较懒,就希望一步到位,思前想后,决定不要注册这步,直接采用短信验证码的进行登录,这样,既安全又简洁,当然了,主要还是人懒;网上搜了很多的短信验证,都要收费,我哭,后来终于发现了http://www.mob.com/ ,提供免费的短信验证码功能,使用该服务需要申请。测试期间短信条数限制:20条/天,APP开发完成后务必提交到mob.com后台审核,开通完全免费短信。多的我就不介绍了,省的大家以为是广告贴,下面我就说说我的集成过程吧:
申请账号,创建应用,获取APP KEY 和 APP Secret
下载SDK,获取相应的aar包
将SDK中的MobCommons.jar,MobTools.jar,SMSSDK-2.0.1.aar,SMSSDKGUI-2.0.1.aar放到了app的libs目录下。然后在app目录下的build.gradle,添加以下代码:
repositories {
flatDir {
dirs 'libs' //就是你放aar的目录地址
}
}
dependencies {
compile name:'SMSSDK-2.1.3',ext:'aar'
}
初始化
SMSSDK.initSDK(this, "您的appkey", "您的appsecret")
发送验证码
SMSSDK.getVerificationCode(getString(R.string.phone_region), tel)
这里是直接调用发送短信验证码的接口,并没有使用内置的开源GUI功能
验证短信验证码
SMSSDK.submitVerificationCode(getString(R.string.phone_region), tel, code)
短信操作回调
SMSSDK.registerEventHandler(eh)
val eh: EventHandler = object : EventHandler() {
override fun afterEvent(event: Int, result: Int, data: Any) {
if (result == SMSSDK.RESULT_COMPLETE) {
if (event == SMSSDK.EVENT_SUBMIT_VERIFICATION_CODE) {
runOnUiThread {
toast("验证码已发送")
}
} else if (event == SMSSDK.EVENT_GET_VERIFICATION_CODE) {
//获取验证码成功
Preference.token = telEt.text.toString()
startActivity()
finish()
} else if (event == SMSSDK.EVENT_GET_SUPPORTED_COUNTRIES) {
//返回支持发送验证码的国家列表
}
} else {
//(data as Throwable).printStackTrace()
runOnUiThread {
toast("验证码错误")
}
}
}
}
最后所有代码如下:
package com.vslimit.concise.activity
import android.os.Bundle
import android.text.TextUtils
import cn.smssdk.EventHandler
import cn.smssdk.SMSSDK
import com.vslimit.concise.R
import com.vslimit.concise.ui.TimerCount
import com.vslimit.concise.utils.Preference
import kotlinx.android.synthetic.main.activity_login.*
import org.jetbrains.anko.onClick
import org.jetbrains.anko.startActivity
import org.jetbrains.anko.toast
/**
* Created by vslimit on 16/2/10.
*/
class LoginActivity : BaseActivity() {
override val layoutResourceId: Int = R.layout.activity_login
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
sendBtn.onClick { attemptSend() }
loginBtn.onClick {
login()
}
SMSSDK.initSDK(this, "您的appkey", "您的appsecret")
SMSSDK.registerEventHandler(eh)
}
val eh: EventHandler = object : EventHandler() {
override fun afterEvent(event: Int, result: Int, data: Any) {
if (result == SMSSDK.RESULT_COMPLETE) {
if (event == SMSSDK.EVENT_SUBMIT_VERIFICATION_CODE) {
runOnUiThread {
toast("验证码已发送")
}
} else if (event == SMSSDK.EVENT_GET_VERIFICATION_CODE) {
//获取验证码成功
Preference.token = telEt.text.toString()
startActivity()
finish()
} else if (event == SMSSDK.EVENT_GET_SUPPORTED_COUNTRIES) {
//返回支持发送验证码的国家列表
}
} else {
//(data as Throwable).printStackTrace()
runOnUiThread {
toast("验证码错误")
}
}
}
}
fun attemptSend() {
val tel = telEt.text.toString()
if (TextUtils.isEmpty(tel)) {
toast("手机号码不能为空")
} else {
val timeCount: TimerCount = TimerCount(60000, 1000, sendBtn)
timeCount.start()
SMSSDK.getVerificationCode(getString(R.string.phone_region), tel)
}
}
fun login() {
val tel = telEt.text.toString()
val code = codeEt.text.toString()
if (TextUtils.isEmpty(tel)) {
toast("手机号码不能为空")
} else if (TextUtils.isEmpty(code)) {
toast("验证码不能为空")
} else {
SMSSDK.submitVerificationCode(getString(R.string.phone_region), tel, code)
}
}
override fun onDestroy() {
super.onDestroy()
SMSSDK.unregisterEventHandler(eh)
}
}
这样,我们就在Android端实现了发送验证码和校验验证码,mob还提供了服务端校验验证码和智能校验验证码的功能,不过一事不烦二主,都在app中搞定。