使用Android SmsRetrieverClient进行SMS验证未解析消息

时间:2018-11-26 18:33:37

标签: android kotlin google-play-services sms-verification

尝试按照以下步骤实施SMS自动读取以进行验证: https://developers.google.com/identity/sms-retriever/request

1)声明

lateinit var smsRetrieverClient: SmsRetrieverClient
private lateinit var smsReceiver: SmsBrReceiver

2)初始化并在登录活动onCreate中注册它们

smsRetrieverClient = SmsRetriever.getClient(this)
smsReceiver = SmsBrReceiver()

val intentFilter = IntentFilter()
intentFilter.addAction(SmsRetriever.SMS_RETRIEVED_ACTION)
applicationContext.registerReceiver(smsReceiver, intentFilter)

val task = smsRetrieverClient.startSmsRetriever()
task.addOnSuccessListener(OnSuccessListener<Void> {
    smsReceiver.setTimeout()
})
task.addOnFailureListener(OnFailureListener { e ->
    showCodeInput()
})

3)制作了SmsRetriever的BroadcastReceiver

inner class SmsBrReceiver : BroadcastReceiver() {
    var h = Handler()
    var r: Runnable = Runnable { doTimeout() }

    fun setTimeout() {
        h.postDelayed(r, 600000)
    }

    override fun onReceive(context: Context, intent: Intent?) {

        val action = intent.action

        if (SmsRetriever.SMS_RETRIEVED_ACTION == action) {

            cancelTimeout()
            val extras = intent.extras
            val status = extras!!.get(SmsRetriever.EXTRA_STATUS) as Status
            when (status.statusCode) {
                CommonStatusCodes.SUCCESS -> { // not called

4)短信格式为

\u200b\u200bPlease enter code: 1111 /appKeyXf56

SMS末尾的应用程序密钥与已安装的应用程序签名密钥生成的密钥相匹配,如下所述: https://developers.google.com/identity/sms-retriever/verify#computing_your_apps_hash_string

CommonStatusCodes.SUCCESS在收到SMS后不会被调用,但是CommonStatusCodes.TIMEOUT会在5分钟后被调用。

缺少什么?万一电话认证的gradle声明是:

com.google.android.gms:play-services-auth-api-phone:16.0.0
classpath "com.google.gms:google-services:4.2.0

1 个答案:

答案 0 :(得分:3)

解决方案是缩短消息,尽管它似乎不超过140个字节。将SMS文本更改为大约30个字符后,无需其他更改即可自动读取SMS。