Исключение базы данных при отображении списка чата в приложении Android Kotlin Chat - PullRequest
0 голосов
/ 02 марта 2019

Я разрабатывал приложение для чата в Android, используя Kotlin и Firebase.Регистрация, поиск и отправка сообщения пользователю, все это прошло успешно.Но я не могу создать список чата, который является списком последних чатов пользователя.Пользователь может нажать на него, чтобы получить доступ к этому конкретному чату, как и в любом другом приложении чата.

Пользователь сохраняется в модели пользователя и данные регистрируются в базе данных в том же формате.

Я могу отобразить изображение профиля пользователя, используя метод addValueEventListener, но когда аналогичный метод вызывается для списка чата, он выдает ошибку - com.google.firebase.database.DatabaseException: Не удается преобразовать объект типаjava.lang.String для ввода kushwaha.samir.boop.models.User

Это код, где возникает ошибка -

val user = snapshot.getValue<User>(User::class.java!!)

присутствует в функции - chatList ()

Просмотр базы данных

Код MainActivityChat>

class MainActivityChat : Fragment() {
    lateinit var profile_image: CircleImageView

    lateinit var firebaseUser: FirebaseUser
    lateinit var reference: DatabaseReference
    lateinit var referenceusers: DatabaseReference
    lateinit var referenceuserschats: DatabaseReference
    lateinit var referencechatlist: DatabaseReference


    var root: View? = null
    lateinit var auth: FirebaseAuth

    lateinit var fragment: Fragment

    var recyclerView: RecyclerView? = null

    var userAdapter: UserAdapter? = null
    var mUsers: MutableList<User>? = null

    var fuser: FirebaseUser?=null

    private var usersList: MutableList<Chatlist>? = null

    override fun onCreateView(inflater: LayoutInflater, container: ViewGroup?, savedInstanceState: Bundle?): View? {
        root = inflater.inflate(R.layout.activity_mainchat, container, false)
        setHasOptionsMenu(true)

        firebaseUser = FirebaseAuth.getInstance().currentUser!!

        val uid = firebaseUser.uid

        val floatingActionButton = root!!.findViewById(R.id.searchPerson) as FloatingActionButton

        floatingActionButton.setOnClickListener {
            val intent = Intent(activity, SearchActivity::class.java)
            startActivity(intent)
        }

        fuser = FirebaseAuth.getInstance().currentUser!!

        usersList = ArrayList()



        reference = FirebaseDatabase.getInstance().getReference("Chatlist").child(fuser!!.uid)
        referencechatlist = FirebaseDatabase.getInstance().getReference("Chatlist").child(fuser!!.uid)


        profile_image = root!!.findViewById(R.id.profile_image)


        firebaseUser = FirebaseAuth.getInstance().currentUser!!
        FirebaseDatabase.getInstance().reference.child("Users").child(uid)
            .addValueEventListener(object : ValueEventListener {

                override fun onDataChange(dataSnapshot: DataSnapshot) {
                    val user = dataSnapshot.getValue(User::class.java)
                    //   usernamedisplay.text = user!!.username
                    if (user!!.profileImageUrl == "default") {
                        profile_image.setImageResource(R.mipmap.ic_launcher)
                        Log.d(ProfileFragment.TAG, "No image retrieved/found")
                    } else {
                        //change this
                        context?.let { Glide.with(it).load(user.profileImageUrl).into(profile_image) }!!
                        Log.d(ProfileFragment.TAG, "Image set")
                    }
                }

                override fun onCancelled(databaseError: DatabaseError) {

                }
            })

        reference = FirebaseDatabase.getInstance().getReference("Chats")
        reference.addValueEventListener(object : ValueEventListener {
            override fun onCancelled(p0: DatabaseError) {
                TODO("not implemented") //To change body of created functions use File | Settings | File Templates.
            }

            override fun onDataChange(dataSnapshot: DataSnapshot) {
                var unread = 0
                for (snapshot in dataSnapshot.children) {
                    val chat = snapshot.getValue<Chat>(Chat::class.java!!)
                    if (chat!!.receiver == firebaseUser!!.uid && !chat!!.isIsseen!!) {
                        unread++
                    }
                }

                reference = FirebaseDatabase.getInstance().getReference("Chatlist").child(fuser!!.uid)
                reference.addValueEventListener(object : ValueEventListener {
                    override fun onDataChange(dataSnapshot: DataSnapshot) {
                        usersList!!.clear()
                        for (snapshot in dataSnapshot.children) {
                            val chatlist = snapshot.getValue<Chatlist>(Chatlist::class.java!!)
                            usersList!!.add(chatlist!!)
                        }

                        chatList()
                    }

                    override fun onCancelled(databaseError: DatabaseError) {

                    }
                })



            }
            })

        updateToken(FirebaseInstanceId.getInstance().token)


        return root
    }

    override fun onViewCreated(view: View, savedInstanceState: Bundle?) {
        super.onViewCreated(view, savedInstanceState)

        recyclerView = view!!.findViewById(R.id.recycler_viewmain)
        recyclerView!!.setHasFixedSize(true)
        recyclerView!!.layoutManager = LinearLayoutManager(context)
    }

    private fun updateToken(token: String?) {
        val reference = FirebaseDatabase.getInstance().getReference("Tokens")
        val token1 = Token(token!!)
        reference.child(fuser!!.uid).setValue(token1)
    }

    private fun chatList() {
        mUsers = ArrayList()
        reference = FirebaseDatabase.getInstance().getReference("Users")

        reference.addValueEventListener(object : ValueEventListener {
            override fun onDataChange(dataSnapshot: DataSnapshot) {
                mUsers!!.clear()
                for (snapshot in dataSnapshot.children) {
                    **val user = snapshot.getValue<User>(User::class.java!!)**
                    for (chatlist in usersList!!) {
                        if (user!!.id == chatlist.id) {
                            mUsers!!.add(user)
                        }
                    }
                }
                userAdapter = UserAdapter(context!!, mUsers!!, true)
                recyclerView!!.adapter = userAdapter
            }

            override fun onCancelled(databaseError: DatabaseError) {

            }
        })

    }


    private fun status(status: String) {
        reference = FirebaseDatabase.getInstance().getReference("Users").child(firebaseUser!!.uid)

        val hashMap = HashMap<String, Any>()
        hashMap["status"] = status

        reference.updateChildren(hashMap)
    }

    override fun onResume() {
        super.onResume()
        status("online")
    }

    override fun onPause() {
        super.onPause()
        status("offline")
    }

    companion object {
        val TAG = "MainActivityChat"
    }
}

Модель пользователя

class User {

  var id: String? = null
  var phoneno: String? = null
  var profileImageUrl: String? = null
  var search: String? = null
  var status: String? = null
  var username: String? = null

  constructor(id: String, phoneno: String, profileImageUrl: String, search: String, status: String, username: String) {
    this.id = id
    this.phoneno = phoneno
    this.profileImageUrl = profileImageUrl
    this.search = search
    this.status = status
    this.username = username
  }

  constructor() {

  }
}

Модель списка чата

import android.os.Parcelable
import kotlinx.android.parcel.Parcelize

@Parcelize
class Chatlist(val id: String):
    Parcelable {
    constructor() : this("")
}

Logcat

2019-03-02 22:20:52.446 20562-20562/kushwaha.samir.boop E/AndroidRuntime: FATAL EXCEPTION: main
    Process: kushwaha.samir.boop, PID: 20562
    com.google.firebase.database.DatabaseException: Can't convert object of type java.lang.String to type kushwaha.samir.boop.models.User
        at com.google.firebase.database.core.utilities.encoding.CustomClassMapper.convertBean(com.google.firebase:firebase-database@@16.0.5:423)
        at com.google.firebase.database.core.utilities.encoding.CustomClassMapper.deserializeToClass(com.google.firebase:firebase-database@@16.0.5:214)
        at com.google.firebase.database.core.utilities.encoding.CustomClassMapper.convertToCustomClass(com.google.firebase:firebase-database@@16.0.5:79)
        at com.google.firebase.database.DataSnapshot.getValue(com.google.firebase:firebase-database@@16.0.5:212)
        at kushwaha.samir.boop.MainActivityChat$chatList$1.onDataChange(MainActivityChat.kt:187)
        at com.google.firebase.database.core.ValueEventRegistration.fireEvent(com.google.firebase:firebase-database@@16.0.5:75)
        at com.google.firebase.database.core.view.DataEvent.fire(com.google.firebase:firebase-database@@16.0.5:63)
        at com.google.firebase.database.core.view.EventRaiser$1.run(com.google.firebase:firebase-database@@16.0.5:55)
        at android.os.Handler.handleCallback(Handler.java:873)
        at android.os.Handler.dispatchMessage(Handler.java:99)
        at android.os.Looper.loop(Looper.java:193)
        at android.app.ActivityThread.main(ActivityThread.java:6762)
        at java.lang.reflect.Method.invoke(Native Method)
        at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:493)
        at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:858)

1 Ответ

0 голосов
/ 03 марта 2019

Согласно вашему комментарию, вы говорите, что когда вы пытаетесь зарегистрировать содержимое вашего snapshot объекта, вы получаете:

{ key = status, value = offline } 

Что, очевидно, означает, что вы используете неправильную ссылку.Таким образом, вы получаете этот результат, потому что вы получаете ссылку в базе данных для свойства status, которое имеет тип String, и именно поэтому вы получаете эту ошибку:

com.google.firebase.database.DatabaseException:Не удается преобразовать объект типа java.lang.String в тип kushwaha.samir.boop.models.User

Чтобы решить эту проблему, измените следующую строку кода:

reference.addValueEventListener(object : ValueEventListener {}

до

val rootRef = FirebaseDatabase.getInstance().getReference()
val usersRef = rootRef.child("Users")
usersRef.addValueEventListener(object : ValueEventListener {}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...