我在实现 IsSerialized 的 GWT 应用程序的客户端定义了 MyObject
,其中 MyObject{String, Timestamp, Timestamp, String}
。
当制作一个简单的 rpc(其中 AsyncCallback>
)时,我收到以下错误:
com.google.gwt.user.client.rpc.StatusCodeException: 500 The call failed on the server; see server log for details
at com.google.gwt.user.client.rpc.impl.RequestCallbackAdapter.onResponseReceived(RequestCallbackAdapter.java:209)
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.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)
at java.lang.reflect.Method.invoke(Unknown Source)
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.entry0(Impl.java:214)
at sun.reflect.GeneratedMethodAccessor16.invoke(Unknown Source)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)
at java.lang.reflect.Method.invoke(Unknown Source)
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(Unknown Source)
我尝试使用 AsyncCallback 仅返回一个 MyObject (而不是 ArrayList) MyObject>
,这也导致了上述错误。
最后,我删除了 Timestamp 属性,这样 MyObject{String, String}
就起作用了,这让我相信序列化 java.sql.Timestamp
存在问题。有人可以对此发表评论并建议我如何最好地进行吗?
我检查了服务器日志,没有发现任何异常。
编辑1:
我已经使用 MyObject{Timestamp}
进行了测试,但也失败了。
到目前为止的解决方案:
相当 hacky,将 MyObject
移动到共享文件夹并将时间戳声明为 transient
,然后将它们转换为 long,以便我可以在客户端使用它们创建一个 Timestamp 对象。丑陋,我知道,但它有效。
I have defined MyObject
on client side of my GWT application that implements IsSerializable
, where MyObject{String, Timestamp, Timestamp, String}
.
When make a simple rpc (where AsyncCallback<ArrayList<MyObject>>
), I get the following error:
com.google.gwt.user.client.rpc.StatusCodeException: 500 The call failed on the server; see server log for details
at com.google.gwt.user.client.rpc.impl.RequestCallbackAdapter.onResponseReceived(RequestCallbackAdapter.java:209)
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.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)
at java.lang.reflect.Method.invoke(Unknown Source)
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.entry0(Impl.java:214)
at sun.reflect.GeneratedMethodAccessor16.invoke(Unknown Source)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)
at java.lang.reflect.Method.invoke(Unknown Source)
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(Unknown Source)
I tried with only returning one MyObject (as opposed to an ArrayList) withAsyncCallback<MyObject>
, which also resulted in the above error.
Finally, I removed the Timestamp properties, so that MyObject{String, String}
, which worked, leading me to believe that there's a problem with serializing java.sql.Timestamp
. Can anybody comment on this and advise me on how best to proceed please?
I checked the server logs and found nothing out of the ordinary.
Edit 1:
I've tested with MyObject{Timestamp}
and that also failed.
Solution so far:
Quite hacky, moved MyObject
to shared folder and declared the Timestamps as transient
, then converted them to longs so that I can create a Timestamp object out of them on client side. Ugly, I know, but it works.
发布评论
评论(2)
我遇到了类似的错误,所以我解决了在 MyObject 类中添加一个空构造函数的问题
我希望这可以帮助别人。
再见。
I had a similar error, so I solved adding a empty contructor in this case in MyObject class
I hope this could help somebody.
Bye.
我非常确定在 GWT 中序列化 java.sql.Timestamp 是可能的。如果有疑问,请阅读 GWT 的可序列化类型:
http://code.google .com/webtoolkit/doc/latest/DevGuideServerCommunication.html#DevGuideSerializedTypes
所以我假设您的调用在您的方法中失败服务器端,而不是在序列化期间。您是否尝试附加调试器来查看服务器端方法中发生了什么?
I' quite sure serializing a
java.sql.Timestamp
is possible in GWT. If in doubt read up on GWT's serializable types:http://code.google.com/webtoolkit/doc/latest/DevGuideServerCommunication.html#DevGuideSerializableTypes
So I assume your call fails in your method on server-side, not during serialization. Did you try to attach a debugger to see what is happening in your server-side method?