Firebase在脱机后持续写入失败

时间:2015-06-22 18:59:23

标签: java android firebase

我有一个使用Firebase作为后端的Android应用程序。现在Firebase支持本地持久性,我决定摆脱我自己的本地存储解决方案并使用内置存储解决方案。

除了一件事,一切都在起作用。在离线时进行更改,关闭应用程序,连接并启动应用程序。

我用来更新服务器上数据的代码是这样的:

public void saveDataToServer(String id, Boolean isHandled) {
    Firebase firebase = new Firebase("https://example.firebaseio.com/item_data/items/1234/data").child(id);
    if(firebase == null)
        return;

    firebase.authWithCustomToken(mToken, mAuthResultHandler);

    Map<String, Object> children = new HashMap<>();
    children.put("updated_at", FireBaseHelper.getFormattedTimestamp());
    children.put("is_handled", isHandled);
    firebase.updateChildren(children);
}

mMainFirebaseInstance是一些Firebase对象,位于保存此数据的根级别。这一切都在Service中运行,并连接到我的活动/片段

旁注: 我从其他人为我使用的REST API中获取了身份验证令牌mToken

当我连接时,请关闭应用并进行更改:一切正常

当我没有连接时,打开应用,进行更改,关闭应用,打开应用并连接:一切正常

当我没有连接时,打开应用程序,进行更改,关闭应用程序,连接并打开应用程序: 记录以下错误:

06-22 17:51:52.343 28073-28395/? W/RepoOperation﹕ Persisted write at /item_data/items/7454/data/7454141033945571998119 failed: FirebaseError: Invalid token in path

我在Firebase的文档中搜索过,无法找出问题所在。我会说这与身份验证有关,但我不知道在哪里看。

所以我的问题是:这里有什么问题?我做错了什么?

编辑:

FireBaseHelper看起来像这样:

class FireBaseHelper {
    public static Firebase getItemsBase(String itemId) {
        Firebase fb = new Firebase(Constants.FIREBASE_URL + "item_data/items/" + itemId + "/data");
        return fb;
    }

    public static String getFormattedTimestamp() {
        SimpleDateFormat simpleDateFormat = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss", Locale.US);
        return simpleDateFormat.format(Calendar.getInstance().getTime());
    }
}

它可以创建主Firebase实例并以特定格式返回时间戳。 Constants.FIREBASE_URL只是https://example.firebaseio.com/

EDIT2:

mMainFirebaseInstance = FireBaseHelper.getItemsBase("1234");

可以替换

mMainFirebaseInstance = new Firebase("https://example.firebaseio.com/item_data/items/1234/data");

可能的时间戳是:

2015-06-22 23:12:24

saveDataToServer中使用的id是从ValueEventListener中提供给我的快照中检索的。例如:

ValueEventListener valueEventListener = new ValueEventListener() {
        @Override
        public void onDataChange(DataSnapshot dataSnapshot) {
            HashMap data = dataSnapshot.getValue(HashMap.class);
            Set keySet = data.keySet();
            String id = keySet.get(0);
        }
        ...
}

EDIT3:

Android:5.0
Firebase:2.3.0+
Java:7

1 个答案:

答案 0 :(得分:1)

这是Firebase Android SDK中的一个错误。它已在刚刚发布的2.3.1版本中得到修复。请参阅https://www.firebase.com/docs/android/changelog.html

我可以使用此totalSold

重现您所看到的行为
Activity.onCreate

重现的步骤与上面的代码一致:

  1. 进入飞行模式
  2. 启动应用(以便它调用@Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); Firebase.setAndroidContext(this); Firebase.getDefaultConfig().setPersistenceEnabled(true); Firebase.getDefaultConfig().setLogLevel(Logger.Level.DEBUG); Firebase ref = new Firebase("https://stackoverflow.firebaseio.com/30987733"); Map<String, Object> children = new HashMap<>(); children.put("updated_at", new Date().toString()); children.put("is_handled", true); ref.updateChildren(children); }
  3. 杀死应用
  4. 上线
  5. 启动应用
  6. 在我的测试中,第二次更新 会写入Firebase。但是在Android日志中写了警告:

    updateChildren