Ошибка RPC после обновления GWT 2.3 - PullRequest
7 голосов
/ 06 мая 2011

После обновления до GWT 2.3 некоторые из моих служб RPC больше не работают и ошибка с «Ответ не может быть десериализован». Кажется случиться с сервисами, которые возвращают объекты, которые используют дату объекты, аннотированные @Temporal (TemporalType.TIMESTAMP). я используйте Gilead 1.3.2 и Hibernate 3.6, и у меня не было проблем с GWT 2.2. Любая идея, что может происходить, или как начать отладку?

Вот трассировка стека:

com.google.gwt.user.client.rpc.IncompatibleRemoteServiceException: The response could not be deserialized
  at com.google.gwt.user.client.rpc.impl.RequestCallbackAdapter.onResponseReceived(RequestCallbackAdapter.java:221)
  at com.google.gwt.http.client.Request.fireOnResponseReceived(Request.java: 287)
  at com.google.gwt.http.client.RequestBuilder$1.onReadyStateChange(RequestBuilder.java:395)
  at sun.reflect.GeneratedMethodAccessor33.invoke(Unknown Source)
  at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImp l.java:25)
  at java.lang.reflect.Method.invoke(Method.java:597) 
  at com.google.gwt.dev.shell.MethodAdaptor.invoke(MethodAdaptor.java:103)
  at com.google.gwt.dev.shell.MethodDispatch.invoke(MethodDispatch.java:71)
  at com.google.gwt.dev.shell.OophmSessionHandler.invoke(OophmSessionHandler.java:167)
  at com.google.gwt.dev.shell.BrowserChannelServer.reactToMessagesWhileWaitingForReturn(BrowserChannelServer.java:326)
  at com.google.gwt.dev.shell.BrowserChannelServer.invokeJavascript(BrowserChannelServer.java:207)
  at com.google.gwt.dev.shell.ModuleSpaceOOPHM.doInvoke(ModuleSpaceOOPHM.java:132)
  at com.google.gwt.dev.shell.ModuleSpace.invokeNative(ModuleSpace.java:561)
  at com.google.gwt.dev.shell.ModuleSpace.invokeNativeObject(ModuleSpace.java:269)
  at com.google.gwt.dev.shell.JavaScriptHost.invokeNativeObject(JavaScriptHost.java:91)
  at com.google.gwt.core.client.impl.Impl.apply(Impl.java)
  at com.google.gwt.core.client.impl.Impl.apply(Impl.java)
  at com.google.gwt.core.client.impl.Impl.entry0(Impl.java:214)
  at sun.reflect.GeneratedMethodAccessor27.invoke(Unknown Source)
  at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
  at java.lang.reflect.Method.invoke(Method.java:597)
  at com.google.gwt.dev.shell.MethodAdaptor.invoke(MethodAdaptor.java:103)
  at com.google.gwt.dev.shell.MethodDispatch.invoke(MethodDispatch.java:71)
  at com.google.gwt.dev.shell.OophmSessionHandler.invoke(OophmSessionHandler.java:167)
  at com.google.gwt.dev.shell.BrowserChannelServer.reactToMessages(BrowserChannelServer.java:281)
  at com.google.gwt.dev.shell.BrowserChannelServer.processConnection(BrowserChannelServer.java:531)
  at com.google.gwt.dev.shell.BrowserChannelServer.run(BrowserChannelServer.java:352)
  at java.lang.Thread.run(Thread.java:680)
Caused by: com.google.gwt.user.client.rpc.SerializationException: java.sql.Timestamp/1769758459
Caused by: com.google.gwt.user.client.rpc.SerializationException: java.sql.Timestamp/1769758459
  at com.google.gwt.user.client.rpc.impl.SerializerBase.getTypeHandler(SerializerBase.java:153)
  at com.google.gwt.user.client.rpc.impl.SerializerBase.instantiate(SerializerBase.java:114)
  at com.google.gwt.user.client.rpc.impl.ClientSerializationStreamReader.deserialize(ClientSerializationStreamReader.java:111)
  at com.google.gwt.user.client.rpc.impl.AbstractSerializationStreamReader.readObject(AbstractSerializationStreamReader.java:119)
  at com.lensoo.shared.entity.Course_FieldSerializer.deserialize(Course_FieldSerializer.java:320)
  at com.lensoo.shared.entity.Course_FieldSerializer.deserial(Course_FieldSerializer.java:405)
  at com.google.gwt.user.client.rpc.impl.SerializerBase.deserialize(SerializerBase.java:95)
  at com.google.gwt.user.client.rpc.impl.ClientSerializationStreamReader.deserialize(ClientSerializationStreamReader.java:113)
  at com.google.gwt.user.client.rpc.impl.AbstractSerializationStreamReader.readObject(AbstractSerializationStreamReader.java:119)
  at com.google.gwt.user.client.rpc.impl.RequestCallbackAdapter$ResponseReader$8.read(RequestCallbackAdapter.java:106) 
  at com.google.gwt.user.client.rpc.impl.RequestCallbackAdapter.onResponseReceived(RequestCallbackAdapter.java:214)
  ... 26 more 
  ... 26 more

Ответы [ 4 ]

3 голосов
/ 10 мая 2011

Если вы не хотите трогать JAR-файлы - когда вы используете Gilead 1.3.2 в качестве зависимости Maven, я нашел лучшее решение, которое я нашел сегодня.

Конфликтующие сериализаторы Gilead должны скрываться отGWT 2.3, но так как оба JAR-файла находятся на одном уровне и расположение inherit в gwt.xml не помогает, их необходимо переопределить в структуре вашего проекта.«Новые» сериализаторы будут иметь приоритет как на сервере, так и на скомпилированном клиенте.Наконец-то вы работаете с GWT 2.3 и Gilead 1.3.2.

По шагам:

  1. Создайте пакет com.google.gwt.user.client.rpc.core.java.sql в своем проекте.
  2. Используя Eclipse open gwt-servlet-2.3.jar и найдите вышеуказанный пакет с тремя файлами Date_CustomFieldSerializer.class, Time_CustomFieldSerializer.class и Timestamp_CustomFieldSerializer.class.Вы должны увидеть исходный код, если Maven скачал его.
  3. Создайте заново эти исходные файлы в вашем проекте.

Я полагаю, команда Gilead должна удалить сериализаторы в следующем выпуске, а затем удалить их из своего проекта какхорошо.

3 голосов
/ 07 мая 2011

У меня очень похожая проблема - Gilead 1.3.1, Hibernate. Исключение также жалуется на поле Timestamp.

Вот что я нашел на сайте Галаад:

"Timestamp_FieldSerializer, который поставляется с Gilead, конфликтует с тем, который был явно представлен в GWT 2.2 или 2.3"

http://sourceforge.net/tracker/index.php?func=detail&aid=3285026&group_id=239931&atid=1111398

Конец раздела «Подробности» предлагает простое исправление, однако я еще не пробовал.

0 голосов
/ 21 августа 2012

Это очень просто.Вам просто нужно удалить пакет com.google.* из gilead4gwt-1.3.2.1839.jar.

Фактически это решает эту проблему.

0 голосов
/ 02 сентября 2011

Просто вы можете найти в [project_path] / war / WEB-INF / lib библиотеку json.jar и добавить ее в путь сборки(Я использую Eclipse).

...