用Gson解析时遇到这个问题
com.google.gson.JsonSyntaxException: 1461689198000 04-27 00:46:51.159 17190-20868/link.ebbinghaus.planning W/System.err: at com.google.gson.internal.bind.DateTypeAdapter.deserializeToDate(DateTypeAdapter.java:74) 04-27 00:46:51.159 17190-20868/link.ebbinghaus.planning W/System.err: at com.google.gson.internal.bind.DateTypeAdapter.read(DateTypeAdapter.java:59) 04-27 00:46:51.159 17190-20868/link.ebbinghaus.planning W/System.err: at com.google.gson.internal.bind.DateTypeAdapter.read(DateTypeAdapter.java:41) 04-27 00:46:51.159 17190-20868/link.ebbinghaus.planning W/System.err: at com.google.gson.internal.bind.ReflectiveTypeAdapterFactory$1.read(ReflectiveTypeAdapterFactory.java:116) 04-27 00:46:51.160 17190-20868/link.ebbinghaus.planning W/System.err: at com.google.gson.internal.bind.ReflectiveTypeAdapterFactory$Adapter.read(ReflectiveTypeAdapterFactory.java:216) 04-27 00:46:51.160 17190-20868/link.ebbinghaus.planning W/System.err: at com.google.gson.internal.bind.ReflectiveTypeAdapterFactory$1.read(ReflectiveTypeAdapterFactory.java:116) 04-27 00:46:51.160 17190-20868/link.ebbinghaus.planning W/System.err: at com.google.gson.internal.bind.ReflectiveTypeAdapterFactory$Adapter.read(ReflectiveTypeAdapterFactory.java:216) 04-27 00:46:51.160 17190-20868/link.ebbinghaus.planning W/System.err: at com.google.gson.Gson.fromJson(Gson.java:879) 04-27 00:46:51.160 17190-20868/link.ebbinghaus.planning W/System.err: at com.google.gson.Gson.fromJson(Gson.java:844) 04-27 00:46:51.160 17190-20868/link.ebbinghaus.planning W/System.err: at com.google.gson.Gson.fromJson(Gson.java:793) 04-27 00:46:51.160 17190-20868/link.ebbinghaus.planning W/System.err: at com.yurikami.lib.net.parser.impl.ModelParser.parse(ModelParser.java:48) 04-27 00:46:51.160 17190-20868/link.ebbinghaus.planning W/System.err: at com.yurikami.lib.net.UICallBack.onResponse(UICallBack.java:54) 04-27 00:46:51.160 17190-20868/link.ebbinghaus.planning W/System.err: at okhttp3.RealCall$AsyncCall.execute(RealCall.java:133) 04-27 00:46:51.160 17190-20868/link.ebbinghaus.planning W/System.err: at okhttp3.internal.NamedRunnable.run(NamedRunnable.java:32) 04-27 00:46:51.160 17190-20868/link.ebbinghaus.planning W/System.err: at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1113) 04-27 00:46:51.160 17190-20868/link.ebbinghaus.planning W/System.err: at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:588) 04-27 00:46:51.160 17190-20868/link.ebbinghaus.planning W/System.err: at java.lang.Thread.run(Thread.java:818) 04-27 00:46:51.160 17190-20868/link.ebbinghaus.planning W/System.err: Caused by: java.text.ParseException: Failed to parse date ["1461689198000']: Invalid time zone indicator '9' (at offset 0) 04-27 00:46:51.160 17190-20868/link.ebbinghaus.planning W/System.err: at com.google.gson.internal.bind.util.ISO8601Utils.parse(ISO8601Utils.java:274) 04-27 00:46:51.160 17190-20868/link.ebbinghaus.planning W/System.err: at com.google.gson.internal.bind.DateTypeAdapter.deserializeToDate(DateTypeAdapter.java:72) 04-27 00:46:51.166 17190-20868/link.ebbinghaus.planning W/System.err: ... 16 more 04-27 00:46:51.166 17190-20868/link.ebbinghaus.planning W/System.err: Caused by: java.lang.IndexOutOfBoundsException: Invalid time zone indicator '9' 04-27 00:46:51.166 17190-20868/link.ebbinghaus.planning W/System.err: at com.google.gson.internal.bind.util.ISO8601Utils.parse(ISO8601Utils.java:245) 04-27 00:46:51.166 17190-20868/link.ebbinghaus.planning W/System.err: ... 17 more
Come from this place~
http://stackoverflow.com/questions/5671373/unparseable-date-1302828677828-trying-to-deserialize-with-gson-a-millisecond
gson deserializes into Date.class operation
gson may not recognize this format by default, and you may need to write a conversion adapter
It solved my problem very well. At first I thought it was gson.setDateFormat(DateFormat.LONG) .