2015-12-30 31 views
1

我試圖從Android更新Firebase對象。其中一個領域是日期com.firebase.client.FirebaseException:無法使用類java.util.Date解析節點android

事情就這麼簡單:

Map<String, Object> fields = new HashMap<String, Object>(); 

fields.put("endDate", new Date()); 
.... some more fields .... 

firebaseRef.updateChildren(fields); 

崩潰,並

Caused by: com.firebase.client.FirebaseException: Failed to parse node with class class java.util.Date 
                   at com.firebase.client.snapshot.NodeUtilities.NodeFromJSON(NodeUtilities.java:84) 
                   at com.firebase.client.snapshot.NodeUtilities.NodeFromJSON(NodeUtilities.java:12) 
                   at com.firebase.client.utilities.Validation.parseAndValidateUpdate(Validation.java:127) 
                   at com.firebase.client.Firebase.updateChildren(Firebase.java:438) 
                   at com.firebase.client.Firebase.updateChildren(Firebase.java:426) 
                   at com.mw.mydot.application.MyApp.updateRideOnPayment(MyApp.java:353) 
                   at com.mw.mydot.FareSummaryActivity.onPaymentReceived(FareSummaryActivity.java:180) 
                   at java.lang.reflect.Method.invokeNative(Native Method)  
                   at java.lang.reflect.Method.invoke(Method.java:515)  
                   at android.support.v7.internal.app.AppCompatViewInflater$DeclaredOnClickListener.onClick(AppCompatViewInflater.java:273)  
                   at android.view.View.performClick(View.java:4456)  
                   at android.view.View$PerformClick.run(View.java:18465)  
                   at android.os.Handler.handleCallback(Handler.java:733)  
                   at android.os.Handler.dispatchMessage(Handler.java:95)  
                   at android.os.Looper.loop(Looper.java:136)  
                   at android.app.ActivityThread.main(ActivityThread.java:5086)  
                   at java.lang.reflect.Method.invokeNative(Native Method)  
                   at java.lang.reflect.Method.invoke(Method.java:515)  
                   at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:785)  
                   at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:601)  
                   at dalvik.system.NativeStart.main(Native Method)  

當我評論與日期字段這條線,所有其它字段都正常更新。

注意:'endDate'字段是我試圖添加到現有對象的新字段。

回答

6

Firebase存儲JSON數據。沒有用JSON表示日期的本機類型。

開發人員通常挑選他們的日期這些表象之一:

  1. 數字時間戳

存儲時間戳(自1970年1月1日的秒/毫秒數)的優點他們是數字,因此可以很容易地進行比較。

將字符存儲爲字符串的優點是,可以很容易地顯示它們,而無需先轉換它們。

如果您需要這兩個屬性,還可以使用兩種格式存儲相關日期/時間:作爲時間戳作爲字符串。

Map<String, Object> fields = new HashMap<String, Object>(); 

fields.put("endDate_timestamp", new Date().getTime()); 
fields.put("endDate_string", new Date().toString()); 

ref.updateChildren(fields); 

如果你做上面,你會考慮讓火力地堡服務器確定時間戳:

fields.put("endDate_server_timestamp", ServerValue.TIMESTAMP); 

這確保了時間戳的精確時刻的值是在服務器上寫匹配。

相關:

+0

那爲什麼沒有在創建對象沒有問題:firebaseRef.setValue(新個MyOwnClass(新的Date(),空,new Date()));工作正常並保存日期。 –

+0

雖然創建對象的firebase本身將日期轉換爲時間。期望它在更新時也是這樣做並不公平。 –

+0

'setValue()'和'updateChildren()'之間的代碼路徑不同。前者比後者執行更多轉換,後者不允許任何非JSON類型。請參閱http://stackoverflow.com/questions/32848024/android-firebase-2-4-illegalstateexception-using-new-ref-updatechildren瞭解更多信息(以及其他可能的解決方法)。 –