FirebaseException:无法使用NodeUtilities.NodeFromJSON中的类解析节点

时间:2013-08-23 01:47:40

标签: java firebase

我在Java中使用Firebase。当用户的信息必须更新时,以下简单代码始终正常工作:

final FirebaseBean_User userObject = new FirebaseBean_User(uuid, name, timestamp, points, gamesPlayed, gamesWon);
mFirebaseUser.setValue(userObject, System.currentTimeMillis());

我使用当前时间戳作为优先级值,以便我可以获得最近在线的所有用户的列表。

但是,当用户离线时,我想将其标记为离线。因此,我在中间再次添加了一个简单的行:

final FirebaseBean_User userObject = new FirebaseBean_User(uuid, name, timestamp, points, gamesPlayed, gamesWon);
mFirebaseUser.onDisconnect().setValue(userObject, USER_PRIORITY_OFFLINE); // best practice: always call onDisconnect() before the actual setValue() operation to prevent ghost data
mFirebaseUser.setValue(userObject, System.currentTimeMillis());

突然间这段代码停止了工作。我得到以下异常,其中导致行(465)是中间的新行:

FATAL EXCEPTION: main
com.firebase.client.FirebaseException: Failed to parse node with class class com.my.package.MultiplayerService$FirebaseBean_User
    at com.firebase.client.snapshot.NodeUtilities.NodeFromJSON(NodeUtilities.java:130)
    at com.firebase.client.OnDisconnect.setValue(OnDisconnect.java:81)
    at com.my.package.MultiplayerService.updateUserInformation(MultiplayerService.java:465)
    at com.my.package.MultiplayerService.access$4(MultiplayerService.java:461)
    at com.my.package.MultiplayerService$1.onDataChange(MultiplayerService.java:83)
    at com.firebase.client.core.ValueListenerContainer$1.run(ValueListenerContainer.java:50)
    at android.os.Handler.handleCallback(Handler.java:605)
    at android.os.Handler.dispatchMessage(Handler.java:92)
    at android.os.Looper.loop(Looper.java:137)
    at android.app.ActivityThread.main(ActivityThread.java:4514)
    at java.lang.reflect.Method.invokeNative(Native Method)
    at java.lang.reflect.Method.invoke(Method.java:511)
    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:790)
    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:557)
    at dalvik.system.NativeStart.main(Native Method)

为什么会这样?我做错了吗?我的意思是,setValue()之前工作正常,现在唯一的变化就是我在onDisconnect()上调用它并且它停止工作。

(如果之前在该参考点有数据,则无关紧要。)

以下是用于参考的类:

private static class FirebaseBean_User {

    private String uuid;
    private String name;
    private int lastlogin;
    private double points;
    private int gamesplayed;
    private int gameswon;

    private FirebaseBean_User() { }

    public FirebaseBean_User(String uuid, String name, int lastlogin, double points, int gamesplayed, int gameswon) {
        this.uuid = uuid;
        this.name = name;
        this.lastlogin = lastlogin;
        this.points = points;
        this.gamesplayed = gamesplayed;
        this.gameswon = gameswon;
    }

    public String getUuid() {
        return uuid;
    }

    public String getName() {
        return name;
    }

    public int getLastlogin() {
        return lastlogin;
    }

    public double getPoints() {
        return points;
    }

    public int getGamesplayed() {
        return gamesplayed;
    }

    public int getGameswon() {
        return gameswon;
    }

    @Override
    public boolean equals(Object o) {
        return (o instanceof FirebaseBean_User && ((FirebaseBean_User) o).getUuid() == this.uuid);
    }

}

2 个答案:

答案 0 :(得分:2)

这实际上是Firebase SDK中的一个错误,对不起!具体来说,这是OnDisconnect处理程序中的一个问题。这就是为什么它适用于ref.setValue,而不是ref.onDisconnect()。setValue。我会尽快得到一个修复程序,并在可用后更新我的答案。

修改:尝试从https://www.firebase.com/docs/downloads.html抓取最新的SDK 它应该是版本1.0.4。如果你继续遇到麻烦,请告诉我。

答案 1 :(得分:0)

在com.firebase.client.snapshot.NodeUtilities类中,似乎是一个JSON解析问题。

我没有在这个类上找到任何文档,但根据我对其他序列化/解析引擎的经验,我怀疑问题出在你的FirebaseBean_User类上,因为缺少一个空的可访问性(如公共)构造函数。

大多数解析引擎最终调用Class<?>.newInstance()方法,实例化调用空构造函数的对象。

所以,试着改变:

private FirebaseBean_User() { }

有:

public FirebaseBean_User() { }