首页 > 解决方案 > Firebase 数据库中的“.info/serverTimeOffset”不刷新

问题描述

我正在构建一个应用程序,其中用户之间的时间同步是一项重要任务。因此,我使用 Firebase .info/serverTimeOffset 在我的 MainActivity“OnCreate”中获取时间偏移并存储在共享首选项中,以便应用程序可以在我的所有片段中使用此变量。我将使用此偏移值和经过的实时时间来计算实际时间。即使用户在应用程序运行时更改系统时间(作弊),实际时间也不会改变,因为我使用的是经过的实时时间。当用户关闭应用程序、更改系统时间并立即重新打开应用程序时,就会出现问题。在这种情况下,再次调用 .info/serverTimeOffset 返回相同的偏移量(不刷新)。从互联网解决方案中,我尝试将“FirebaseDatabase.getInstance().goOffline() 和 FirebaseDatabase.getInstance() &


    class MainActivity : AppCompatActivity() {


        override fun onCreate(savedInstanceState: Bundle?) {
            super.onCreate(savedInstanceState)
            setContentView(R.layout.activity_main)
            Log.i("ph","MainActivity OnCreate")
            calculateDelay(this)
        }

        override fun onDestroy() {
            super.onDestroy()
            Log.i("ph","MainActivity OnDestroy")
        }

        private fun calculateDelay(ac: Context) {
            FirebaseDatabase.getInstance().goOffline()
            FirebaseDatabase.getInstance().goOnline()
            val offsetRef = FirebaseDatabase.getInstance().getReference(".info/serverTimeOffset")
            offsetRef.addListenerForSingleValueEvent(object : ValueEventListener {
                override fun onDataChange(snapshot: DataSnapshot) {

                    val systemTimeOffset = snapshot.getValue(Long::class.java) ?: 0L
                    val estimatedOffset =
                        System.currentTimeMillis() + systemTimeOffset - SystemClock.elapsedRealtime()
                    val estimatedServerTimeMs =
                        estimatedOffset + SystemClock.elapsedRealtime()
                    Log.i("ph","Main Time " + getdate(estimatedServerTimeMs, "dd/MM/yyyy hh:mm:ss.SSS"))
                    val sPreference = SPreference(ac) // my preference class 
                    sPreference.putTD(estimatedOffset) // saving to preference
                }

                override fun onCancelled(p0: DatabaseError) {
                    TODO("not implemented") //To change body of created functions use File | Settings | File Templates.
                }
            })
        }
    }

如何引用 .info/serverTimeOffset ?

标签: androidfirebasefirebase-realtime-database

解决方案


.info/serverTimeOffset是在客户端首次与服务器建立连接时计算的。之后不再重新计算。因此,您看到的行为按预期工作。

您必须找到另一种方法来处理应用程序运行时更改的时钟。


我刚才做了一个快速测试,.info/serverTimeOffset如果你循环通过goOffline()/ ,(至少是 JavaScript SDK)似乎会重新计算值goOnline()。您可能想测试 Android SDK 的行为是否相同。

我的测试:https ://jsbin.com/wazajid/edit?js,console


推荐阅读