Безумная ситуация SmartGWT + GWT Ошибка при создании экземпляра ListGridRecord?

Я спрашиваю об этом здесь в надежде, что кто-то, возможно, тоже сталкивался с этой ситуацией... Я разместил это на форуме SmartGWT:

У меня возникла проблема при попытке создать экземпляр объекта ListGridRecord на стороне сервера. Я использую ListGrid на стороне клиента, я хочу использовать RPC GWT для передачи массива объектов ListGridRecord для заполнения сетки. Я знаю, что SmartGWT предназначен для ссылки на источник данных, но я хочу иметь полный контроль над заполнением сетки, и это не должно быть таким кошмаром, как должно быть.

Я искал повсюду и не мог найти никого, кто жалуется на одно и то же. Однако исключение (перечисленное ниже) возникло (в моих результатах поиска) как возможная ошибка памяти, где увеличение памяти (аргумент -Xmx512m), по-видимому, решило проблему. Однако это не помогло мне разобраться.

Если кто-то может пролить свет на это, я был бы очень признателен!

Вот мои данные:

При разработке с использованием Eclipse Galileo в Ubuntu 9.04 (Jaunty) и GWT 2.0.3 я создал первоначальный проект GWT с помощью webAppCreator, входящего в состав выпуска GWT 2.0.3, и импортировал проект в Eclipse, как описано на странице «Начало работы с GWT» (как использование плагин GWT Eclipse вызывал еще больше кошмаров при попытке подключения к базе данных - очевидно, это связано с использованием Google App Engine и его отключением, поскольку все предлагаемые сообщения вызывают только исключения ClassNotFound).

Строка, которая вызывает ошибку, буквально:

ListGridRecord a = new ListGridRecord();

Ошибка, которую я получаю, следующая:

00:00:25.916 [WARN] Exception while dispatching incoming RPC call
com.google.gwt.user.server.rpc.UnexpectedException : Service method 'public abstract java.lang.String za.co.company.product.client.service.EmployeeService.getAllEmployeeAsListGridRecord()' threw an unexpected exception: java.lang.UnsatisfiedLinkError: com.smartgwt.client.util.LogUtil.setJSNIErrorHandler()V
at com.google.gwt.user.server.rpc.RPC.encodeResponseForFailure(RPC.java:378)
at com.google.gwt.user.server.rpc.RPC.invokeAndEncodeResponse(RPC.java:581)
at com.google.gwt.user.server.rpc.RemoteServiceServlet.processCall(RemoteServiceServlet.java:188)
at com.google.gwt.user.server.rpc.RemoteServiceServlet.processPost(RemoteServiceServlet.java:224)
at com.google.gwt.user.server.rpc.AbstractRemoteServiceServlet.doPost(AbstractRemoteServiceServlet.java :62)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:637)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:717)
at org.mortbay.jetty.servlet.ServletHolder.handle(ServletHolder.java:487)
at org.mortbay.jetty.servlet.ServletHandler.handle(ServletHandler.java:362)
at org.mortbay.jetty.security.SecurityHandler.handle(SecurityHandler.java:216)
at org.mortbay.jetty.servlet.SessionHandler.handle(SessionHandler.java:181)
at org.mortbay.jetty.handler.ContextHandler.handle(ContextHandler.java:729)
at org.mortbay.jetty.webapp.WebAppContext.handle(WebAppContext.java:405)
at org.mortbay.jetty.handler.HandlerWrapper.handle(HandlerWrapper.java:152)
at org.mortbay.jetty.handler.RequestLogHandler.handle(RequestLogHandler.java:49)
at org.mortbay.jetty.handler.HandlerWrapper.handle(HandlerWrapper.java:152)
at org.mortbay.jetty.Server.handle(Server.java:324)
at org.mortbay.jetty.HttpConnection.handleRequest(HttpConnection.java:505)
at org.mortbay.jetty.HttpConnection$RequestHandler.content(HttpConnection.java:843)
at org.mortbay.jetty.HttpParser.parseNext(HttpParser.java:647)
at org.mortbay.jetty.HttpParser.parseAvailable(HttpParser.java:211)
at org.mortbay.jetty.HttpConnection.handle(HttpConnection.java:380)
at org.mortbay.io.nio.SelectChannelEndPoint.run(SelectChannelEndPoint.java:395)
at org.mortbay.thread.QueuedThreadPool$PoolThread.run(QueuedThreadPool.java:488) Caused by: java.lang.UnsatisfiedLinkError: com.smartgwt.client.util.LogUtil.setJSNIErrorHandl er()V
at com.smartgwt.client.util.LogUtil.setJSNIErrorHandler(Native Method)
at com.smartgwt.client.core.JsObject.<clinit>(JsObject.java:30)
at za.co.company.product.server.service.EmployeeServiceImpl.getAllEmployeeAsListGridRecord(EmployeeServ iceImpl.java:83)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
at java.lang.reflect.Method.invoke(Method.java:597)
at com.google.gwt.user.server.rpc.RPC.invokeAndEncodeResponse(RPC.java:562)
at com.google.gwt.user.server.rpc.RemoteServiceServlet.processCall(RemoteServiceServlet.java:188)
at com.google.gwt.user.server.rpc.RemoteServiceServlet.processPost(RemoteServiceServlet.java:224)
at com.google.gwt.user.server.rpc.AbstractRemoteServiceServlet.doPost(AbstractRemoteServiceServlet.java :62)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:637)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:717)
at org.mortbay.jetty.servlet.ServletHolder.handle(ServletHolder.java:487)
at org.mortbay.jetty.servlet.ServletHandler.handle(ServletHandler.java:362)
at org.mortbay.jetty.security.SecurityHandler.handle(SecurityHandler.java:216)
at org.mortbay.jetty.servlet.SessionHandler.handle(SessionHandler.java:181)
at org.mortbay.jetty.handler.ContextHandler.handle(ContextHandler.java:729)
at org.mortbay.jetty.webapp.WebAppContext.handle(WebAppContext.java:405)
at org.mortbay.jetty.handler.HandlerWrapper.handle(HandlerWrapper.java:152)
at org.mortbay.jetty.handler.RequestLogHandler.handle(RequestLogHandler.java:49)
at org.mortbay.jetty.handler.HandlerWrapper.handle(HandlerWrapper.java:152)
at org.mortbay.jetty.Server.handle(Server.java:324)
at org.mortbay.jetty.HttpConnection.handleRequest(HttpConnection.java:505)
at org.mortbay.jetty.HttpConnection$RequestHandler.content(HttpConnection.java:843)
at org.mortbay.jetty.HttpParser.parseNext(HttpParser.java:647)
at org.mortbay.jetty.HttpParser.parseAvailable(HttpParser.java:211)
at org.mortbay.jetty.HttpConnection.handle(HttpConnection.java:380)
at org.mortbay.io.nio.SelectChannelEndPoint.run(SelectChannelEndPoint.java:395)
at org.mortbay.thread.QueuedThreadPool$PoolThread.run(QueuedThreadPool.java:488)

Заранее спасибо!

Ксандел


person Xandel    schedule 23.04.2010    source источник


Ответы (2)


Я нашел ответ/решение здесь.

Суть в том, что вы не можете создать экземпляр объекта Record или ListGridRecord на стороне сервера, потому что он напрямую связан с JavaScript и предназначен только для клиентской стороны...

Надеюсь, это кому-нибудь поможет!

person Xandel    schedule 23.04.2010

В целом можно сказать, что все, что принадлежит SmartGWT JAR, никогда не должно использоваться на сервере. Чтобы избежать неправильного использования, вы можете создать три проекта и разделить классы на 1. клиентскую часть 2. сервисные интерфейсы 3. серверную часть

но это, вероятно, не стоит хлопот, я думаю, вы знаете, что искать в следующий раз, когда это произойдет :-)

person dube    schedule 28.04.2010
comment
Действительно буду! Это сводило меня с ума! :) Теперь я очень осторожен с тем, где я что кодирую... :P - person Xandel; 29.04.2010