Ошибка RPC после обновления GWT 2.3

#gwt #gwt-rpc #gilead

#gwt #gwt-rpc #gilead

Вопрос:

После обновления до GWT 2.3 некоторые из моих RPC-сервисов больше не работают и завершаются сбоем с сообщением «Ответ не удалось десериализовать». Похоже, это происходит со службами, которые возвращают объекты, являющиеся объектами даты использования, которые помечены @Temporal (TemporalType.ВРЕМЕННАЯ МЕТКА). Я использую 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
  

Комментарии:

1. Вы также обновились до GWT 2.3 на стороне службы? Есть ли трассировка стека с сервера?

2. Возможно, объекты, которые вы используете, не реализуют сериализуемый интерфейс, вот что я думаю.

3. Исправлена ли эта проблема в более поздних выпусках GWT? (Я пытаюсь обновиться до 2.5.0-rc1) Или нам нужно применить исправление наверняка? (Gilead 1.3.2)

Ответ №1:

У меня очень похожая проблема — Gilead 1.3.1, спящий режим. Исключение также выдает ошибку в поле метки времени.

Вот что я нашел на веб-сайте Gilead:

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

http://sourceforge.net/tracker/index.php?func=detailamp;aid=3285026amp;group_id=239931amp;atid=1111398

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

Комментарии:

1. Спасибо за помощь. Для любопытных удалите пакет com.google.gwt.user.client.rpc.core.java.sql из gilead4gwt.jar

Ответ №2:

Если вы не хотите прикасаться к JARS — когда вы используете Gilead 1.3.2 в качестве Maven dependecy, есть лучшее решение, которое я нашел сегодня.

Конфликтующие сериализаторы 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 откройте gwt-servlet-2.3.jar и найдите вышеуказанный пакет с тремя файлами Date_CustomFieldSerializer.class , Time_CustomFieldSerializer.class и Timestamp_CustomFieldSerializer.class . Вы должны увидеть исходный код, если Maven загрузил его.
  3. Воссоздайте эти исходные файлы в своем проекте.

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

Ответ №3:

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

Ответ №4:

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

На самом деле это решает эту проблему.