Firebase数据库中的“ .info / serverTimeOffset”未刷新

时间:2019-12-25 02:45:27

标签: android firebase firebase-realtime-database

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


    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?

1 个答案:

答案 0 :(得分:0)

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

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


我刚刚进行了一次快速测试,并且(如果至少循环一次.info/serverTimeOffset / goOffline(),(至少是JavaScript SDK)似乎重新计算了goOnline()值。您可能需要测试Android SDK的行为是否相同。

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