E / FirebaseInstanceId: сбой получения токена: PHONE_REGISTRATION_ERROR в Android Kitkat и ниже - PullRequest
0 голосов
/ 05 декабря 2018

Edit: я забыл сказать, я уже пытаюсь сделать точку останова на onRefreshToken и сделать Log в этой функции, но когда я запускаю приложения, ни одно из них не работает (точка останова не запускается,и Log не отображается в журнале консоли AS).Так что IMO чисто, что сама служба не запускается.


Я делаю код, где мои приложения будут показывать уведомление, если в onMessageReceived поступают данные. Он может работать нормально, никаких проблем, пока я не попробую его в Android Jelly Bean .

Уведомление не отображается ( Я уверен, что уведомление отправлено, потому чтодругое устройство, не являющееся JellyBean, одновременно показывает уведомление. ), а затем я пробую его в KitKat Device, результат такой же .

Затем я пытаюсь отладить егои никаких ошибок в Android Studio (я держу пари, потому что устройство получило китайский rom и не имеет встроенного сервиса Google Play).

Позже я меняю свой метод и пробую его в эмуляторе, а E/FirebaseInstanceId: Token retrieval failed: PHONE_REGISTRATION_ERRORпоказывает.Я уже пробовал его в эмуляторе с установленным образом KitKat и JellyBean, результат тот же, появляется то же сообщение.

Это мой код:

AndroidManifest

<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    package="com.appname">

///Some activity and meta data here

    <service
        android:name=".fcm.MyFirebaseInstanceIdService"
        android:enabled="true"
        android:exported="true"
        tools:ignore="ExportedService">
        <intent-filter>
            <action android:name="com.google.firebase.INSTANCE_ID_EVENT"/>
        </intent-filter>
    </service>
    <service
        android:name=".fcm.MyFirebaseMessagingService"
        android:enabled="true"
        android:exported="true"
        tools:ignore="ExportedService">
        <intent-filter>
            <action android:name="com.google.firebase.MESSAGING_EVENT"/>
        </intent-filter>
    </service>
</manifest>

MyFirebaseInstanceIdService

class MyFirebaseInstanceIdService : FirebaseInstanceIdService() {
    val TAG = "PushNotifService"
    lateinit var name: String

    override fun onTokenRefresh() {
        val token = FirebaseInstanceId.getInstance().token
    }
}

MyFirebaseMessagingService

class MyFirebaseMessagingService : FirebaseMessagingService() {

    private val session = SessionManagement(this)

    @SuppressLint("LongLogTag")
    override fun onMessageReceived(remoteMessage: RemoteMessage) {
        if (remoteMessage.data != null){
            val data = remoteMessage.data
            val title = data["title"]
            val body = data["body"]
            showNotification(title, body)
        }
    }

    @SuppressLint("LongLogTag")
    override fun onNewToken(token: String?) {
        session.updateFCMToken(token)
    }

    fun subscribeTopic(topic: String?){

//the topic in here is a param send by other activity when the apps lunch 

FirebaseMessaging.getInstance().subscribeToTopic(topic).addOnCompleteListener { task ->
            if (!task.isSuccessful) {
            } else {
            }
        }
    }

//This sendMessageTrainer() is called and run from other activity

    fun sendMessageTrainer(){
        val contentType = "application/json"
        val authorizationKey = ServerHelper.FCMServerKey
        val data = "{\"to\": \"/topics/sometopic\",\"data\": {\"title\":\"Request Update\",\"body\":\"New Request.\"}}"
        Fuel.post(ServerHelper.FCMServer).header("Content-Type" to contentType, "Authorization" to "key=$authorizationKey").body(data).responseJson{
            _, _, result ->
            result.failure {
                sendMessageTrainer()
            }
            result.success {
            }
        }
    }


//showNotification() is run if there is a new data/notification from onMessageReceived 

    private fun showNotification(title: String?, body: String?) {
        val intent = Intent(this, LauncherActivity::class.java)
        intent.addFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP)
        val pendingIntent = PendingIntent.getActivity(this, 0, intent, PendingIntent.FLAG_ONE_SHOT)
        val channelName = getString(R.string.app_name)
        val channelID = "default"
        val alarmSound = RingtoneManager.getDefaultUri(RingtoneManager.TYPE_NOTIFICATION)
        val notifyID = 1
        val notification = NotificationCompat.Builder(this, channelID)
                .setSmallIcon(R.drawable.ic_logo)
                .setContentTitle(title)
                .setContentText(body)
                .setAutoCancel(true)
                .setSound(alarmSound)
                .setContentIntent(pendingIntent)
                .build()
        when {
            Build.VERSION.SDK_INT >= Build.VERSION_CODES.O -> {
                val importance = NotificationManager.IMPORTANCE_HIGH
                val mChannel = NotificationChannel(channelID, channelName, importance)
                val mNotificationManager = getSystemService(Context.NOTIFICATION_SERVICE) as NotificationManager
                mNotificationManager.createNotificationChannel(mChannel)
                mNotificationManager.notify(notifyID , notification)
            }
            Build.VERSION.SDK_INT <= Build.VERSION_CODES.N -> {
                val mNotificationManager = getSystemService(Context.NOTIFICATION_SERVICE) as NotificationManager
                mNotificationManager.notify(notifyID, notification)
            }
        }
    }
}

С уважением,

vl14b

...