#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»
В конце раздела «Подробности» предлагается простое исправление, однако я этого еще не пробовал.
Комментарии:
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.
Пошагово:
- Создайте пакет
com.google.gwt.user.client.rpc.core.java.sql
в своем проекте. - С помощью Eclipse откройте
gwt-servlet-2.3.jar
и найдите вышеуказанный пакет с тремя файламиDate_CustomFieldSerializer.class
,Time_CustomFieldSerializer.class
иTimestamp_CustomFieldSerializer.class
. Вы должны увидеть исходный код, если Maven загрузил его. - Воссоздайте эти исходные файлы в своем проекте.
Я полагаю, что команда Gilead должна удалить сериализаторы в следующем выпуске, тогда вы также удалите их из своего проекта.
Ответ №3:
Просто вы можете выполнить поиск в [project_path]/war/WEB-INF/lib для библиотеки json.jar и добавьте ее в путь сборки (я использую Eclipse).
Ответ №4:
Это очень просто. Вам просто нужно удалить com.google.*
пакет из gilead4gwt-1.3.2.1839.jar
.
На самом деле это решает эту проблему.