android - 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 ?
解决方案
.info/serverTimeOffset
是在客户端首次与服务器建立连接时计算的。之后不再重新计算。因此,您看到的行为按预期工作。
您必须找到另一种方法来处理应用程序运行时更改的时钟。
我刚才做了一个快速测试,.info/serverTimeOffset
如果你循环通过goOffline()
/ ,(至少是 JavaScript SDK)似乎会重新计算值goOnline()
。您可能想测试 Android SDK 的行为是否相同。
推荐阅读
- c# - 为什么找不到正确的标签(标签为空)?
- javascript - React,如何在使用 ref 在外部单击时不放松对元素的关注?
- nginx - Nginx 配置在 MacOS High Sierra 上不受影响
- json - 尝试 diff '[object Object]' 时出错,需要传递错误消息
- ssas - 在 DAX 中优化汇总
- vba - 从 VBA 运行 PowerShell FTP 上传脚本并发出带有结果的消息框
- python - Python,提高 for 循环性能
- junit - 使用 Ivy(不是 Gradle 或 Maven)从 JUnit 4 升级到 JUnit 5
- linux - 获取打开文件描述符的内存使用情况
- javascript - 按钮单击一次即可更新