2011-02-27 24 views
0

在我的GWT客戶端,我從服務器端請求一個LightEntities列表。我對這些實體進行了一些修改,並且嘗試將它們發回以進行保存。GWT GiLead休眠IllegalArgumentException異常嘗試發送LightEntity throw wire

當我做RPC調用失敗但下列情況除外:

[WARN] Exception while dispatching incoming RPC call 
java.lang.RuntimeException: java.lang.IllegalArgumentException: argument type mismatch 
    at net.sf.gilead.core.beanlib.merge.MergePropertyFilter.propagate(MergePropertyFilter.java:230) 
    at net.sf.beanlib.provider.BeanPopulator.doit(BeanPopulator.java:186) 
    at net.sf.beanlib.provider.BeanPopulator.processSetterMethod(BeanPopulator.java:172) 
    at net.sf.beanlib.provider.BeanPopulator.populate(BeanPopulator.java:269) 
    at net.sf.gilead.core.LazyKiller.populate(LazyKiller.java:288) 
    at net.sf.gilead.core.LazyKiller.attach(LazyKiller.java:237) 
    at net.sf.gilead.core.PersistentBeanManager.mergePojo(PersistentBeanManager.java:554) 
    at net.sf.gilead.core.PersistentBeanManager.merge(PersistentBeanManager.java:318) 
    at net.sf.gilead.core.PersistentBeanManager.mergeCollection(PersistentBeanManager.java:581) 
    at net.sf.gilead.core.PersistentBeanManager.merge(PersistentBeanManager.java:290) 
    at net.sf.gilead.gwt.GileadRPCHelper.parseInputParameters(GileadRPCHelper.java:94) 
    at net.sf.gilead.gwt.GileadRPCHelper.parseInputParameters(GileadRPCHelper.java:137) 
    at net.sf.gilead.gwt.PersistentRemoteService.processCall(PersistentRemoteService.java:172) 
    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.IllegalArgumentException: argument type mismatch 
    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 net.sf.gilead.core.beanlib.merge.MergePropertyFilter.writePropertyValue(MergePropertyFilter.java:285) 
    at net.sf.gilead.core.beanlib.merge.MergePropertyFilter.propagate(MergePropertyFilter.java:179) 

我坐在這個錯誤小時了,這就是LazyKiller是殺了我,我應該在哪裏再看任何提示?

回答

0

我試圖用基列,但它是不好:

  1. 它是如此的侵入;
  2. 它很難配置。

我寫了一個小型的類,它將hibernate代理轉換爲普通的java類,它確實幫助了我。 它作爲開源共享那裏,所以你可以嘗試:

http://code.google.com/p/dehibernator/

+0

我會嘗試了這一點,如果這個工程,我會高興地扔了出去GILEAD,謝謝。 – Stoto 2011-03-01 06:45:05

0

我無法解決這個問題,但我做了一個小小的解決方法: 我在客戶端克隆我的實體,然後我可以將它們發回服務器端。