JPA和GWT失败

JPA和GWT失败,gwt,jpa,datanucleus,Gwt,Jpa,Datanucleus,我正在尝试将JPA与GWT结合使用 我的serviceImpl呼叫 UserDAO.exists(user); 当我使用相同的参数运行一个调用相同方法的测试用例时,它运行正常。当我执行RPC调用时,if会严重失败(最后出现错误) 当我将persistence.xml重命名为someothername.xml时,我得到了相同的错误,因此我倾向于认为GWT(在开发模式中)没有读取我的persistence.xml 错误: Starting Jetty on port 8888 [WARN]

我正在尝试将JPA与GWT结合使用

我的serviceImpl呼叫

UserDAO.exists(user);
当我使用相同的参数运行一个调用相同方法的测试用例时,它运行正常。当我执行RPC调用时,if会严重失败(最后出现错误)

当我将persistence.xml重命名为someothername.xml时,我得到了相同的错误,因此我倾向于认为GWT(在开发模式中)没有读取我的persistence.xml

错误:

Starting Jetty on port 8888
   [WARN] Exception while dispatching incoming RPC call
com.google.gwt.user.server.rpc.UnexpectedException: Service method 'public abstract hobarrera.client.dto.main.UserRegDTO hobarrera.client.services.AuthService.selfRegisterUser(java.lang.String,java.lang.String,java.lang.String,java.lang.String) throws hobarrera.client.exceptions.MyCustomizedException' threw an unexpected exception: java.lang.ExceptionInInitializerError
 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.ExceptionInInitializerError
 at hobarrera.server.DAO.EntityManagerFactory.createEntityManager(EntityManagerFactory.java:13)
 at hobarrera.server.DAO.UsuarioDAO.userNameExists(UsuarioDAO.java:52)
 at hobarrera.server.services.AuthServiceImpl.selfRegisterUser(AuthServiceImpl.java:60)
 at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
 at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)
 at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
 at java.lang.reflect.Method.invoke(Method.java:616)
 at com.google.gwt.user.server.rpc.RPC.invokeAndEncodeResponse(RPC.java:562)
 ... 22 more
Caused by: javax.persistence.PersistenceException: No resource files named META-INF/services/javax.persistence.spi.PersistenceProvider were found. Please make sure that the persistence provider jar file is in your classpath.
 at javax.persistence.Persistence.findAllProviders(Persistence.java:167)
 at javax.persistence.Persistence.createEntityManagerFactory(Persistence.java:103)
 at javax.persistence.Persistence.createEntityManagerFactory(Persistence.java:83)
 at hobarrera.server.DAO.EntityManagerFactory$RealEntityManagerFactoryContainer.<clinit>(EntityManagerFactory.java:9)
 ... 30 more
[ERROR] 500 - POST /desarrollonew/greet (0:0:0:0:0:0:0:1) 57 bytes
   Request headers
      Host: localhost:8888
      User-Agent: Mozilla/5.0 (X11; U; Linux x86_64; en-US; rv:1.9.1.8) Gecko/20100216 Fedora/3.5.8-1.fc12 Firefox/3.5.8
      Accept: text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8
      Accept-Language: en-us,en;q=0.5
      Accept-Encoding: gzip,deflate
      Accept-Charset: ISO-8859-1,utf-8;q=0.7,*;q=0.7
      Keep-Alive: 300
      Connection: keep-alive
      Referer: http://localhost:8888/desarrollonew/hosted.html?desarrollonew
      Cache-Control: no-cache
      X-GWT-Permutation: HostedMode
      X-GWT-Module-Base: http://localhost:8888/desarrollonew/
      Content-Type: text/x-gwt-rpc; charset=utf-8
      Content-Length: 187
      Pragma: no-cache
   Response headers
      Content-Type: text/plain
在8888港启动码头
[警告]调度传入RPC调用时发生异常
com.google.gwt.user.server.rpc.UnexpectedException:服务方法'public abstract hobarrra.client.dto.main.UserRegDTO hobarrra.client.services.AuthService.selfRegisterUser(java.lang.String,java.lang.String,java.lang.String,java.lang.String)抛出Hobarera.client.exceptions.MyCustomizedException'引发意外异常:java.lang.ExceptionInInitializeError
位于com.google.gwt.user.server.rpc.rpc.encodeResponseForFailure(rpc.java:378)
位于com.google.gwt.user.server.rpc.rpc.invokeAndEncodeResponse(rpc.java:581)
位于com.google.gwt.user.server.rpc.RemoteServiceServlet.processCall(RemoteServiceServlet.java:188)
位于com.google.gwt.user.server.rpc.RemoteServiceServlet.processPost(RemoteServiceServlet.java:224)
位于com.google.gwt.user.server.rpc.AbstractRemoteServiceServlet.doPost(AbstractRemoteServiceServlet.java:62)
位于javax.servlet.http.HttpServlet.service(HttpServlet.java:637)
位于javax.servlet.http.HttpServlet.service(HttpServlet.java:717)
位于org.mortbay.jetty.servlet.ServletHolder.handle(ServletHolder.java:487)
位于org.mortbay.jetty.servlet.ServletHandler.handle(ServletHandler.java:362)
位于org.mortbay.jetty.security.SecurityHandler.handle(SecurityHandler.java:216)
位于org.mortbay.jetty.servlet.SessionHandler.handle(SessionHandler.java:181)
位于org.mortbay.jetty.handler.ContextHandler.handle(ContextHandler.java:729)
位于org.mortbay.jetty.webapp.WebAppContext.handle(WebAppContext.java:405)
位于org.mortbay.jetty.handler.HandlerWrapper.handle(HandlerWrapper.java:152)
位于org.mortbay.jetty.handler.RequestLogHandler.handle(RequestLogHandler.java:49)
位于org.mortbay.jetty.handler.HandlerWrapper.handle(HandlerWrapper.java:152)
位于org.mortbay.jetty.Server.handle(Server.java:324)
位于org.mortbay.jetty.HttpConnection.handleRequest(HttpConnection.java:505)
位于org.mortbay.jetty.HttpConnection$RequestHandler.content(HttpConnection.java:843)
位于org.mortbay.jetty.HttpParser.parseNext(HttpParser.java:647)
位于org.mortbay.jetty.HttpParser.parseAvailable(HttpParser.java:211)
位于org.mortbay.jetty.HttpConnection.handle(HttpConnection.java:380)
位于org.mortbay.io.nio.SelectChannelEndPoint.run(SelectChannelEndPoint.java:395)
位于org.mortbay.thread.QueuedThreadPool$PoolThread.run(QueuedThreadPool.java:488)
原因:java.lang.ExceptionInInitializeError
位于hobarera.server.DAO.EntityManagerFactory.createEntityManager(EntityManagerFactory.java:13)
位于hobarera.server.DAO.UsuarioDAO.userNameExists(UsuarioDAO.java:52)
位于hobarera.server.services.AuthServiceImpl.selfRegisterUser(AuthServiceImpl.java:60)
在sun.reflect.NativeMethodAccessorImpl.invoke0(本机方法)处
在sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)中
在sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)中
位于java.lang.reflect.Method.invoke(Method.java:616)
位于com.google.gwt.user.server.rpc.rpc.invokeAndEncodeResponse(rpc.java:562)
... 还有22个
原因:javax.persistence.PersistenceException:未找到名为META-INF/services/javax.persistence.spi.PersistenceProvider的资源文件。请确保持久性提供程序jar文件位于类路径中。
位于javax.persistence.persistence.findAllProviders(persistence.java:167)
位于javax.persistence.persistence.createEntityManagerFactory(persistence.java:103)
位于javax.persistence.persistence.createEntityManagerFactory(persistence.java:83)
位于hobarera.server.DAO.EntityManagerFactory$RealEntityManagerFactoryContainer。(EntityManagerFactory.java:9)
... 30多
[错误]500-POST/desarrollonew/greet(0:0:0:0:0:0:1)57字节
请求头
主机:localhost:8888
用户代理:Mozilla/5.0(X11;U;Linux x86_64;en-US;rv:1.9.1.8)Gecko/20100216 Fedora/3.5.8-1.fc12 Firefox/3.5.8
接受:text/html、application/xhtml+xml、application/xml;q=0.9,*/*;q=0.8
接受语言:en-us,en;q=0.5
接受编码:gzip,deflate
接受字符集:ISO-8859-1,utf-8;q=0.7,*;q=0.7
活命:300
连接:保持活力
推荐人:http://localhost:8888/desarrollonew/hosted.html?desarrollonew
缓存控制:没有缓存
X-GWT-置换:HostedMode
X-GWT-Module-Base:http://localhost:8888/desarrollonew/
内容类型:text/x-gwt-rpc;字符集=utf-8
内容长度:187
Pragma:没有缓存
响应头
内容类型:文本/纯文本
[编辑]
GWT似乎在某个地方有自己的persistence.xml文件(我想是供内部使用的)。 这就是为什么将persistence.xml重命名为somethingelse.xml仍然会产生相同的错误:正在读取的persistence.xml文件一直都是GWT的


所以现在我的问题是:我如何覆盖它,强制使用另一个,或者不使用它?

您没有在类路径中添加JPA实现。在您的类路径中放置datanucleus的jar(或toplink,或您正在使用的任何东西),它负责实体管理器的创建。

您在
WEB-INF/lib
中有datanucleus jar吗?

因为这是我第n次建议为GWT切换到外部服务器,让我引用一下(有关GWT嵌入式码头问题的更深入解释,请阅读完整答案):

我建议你换成一个 外部Java服务器(如Tomcat、, 您似乎已经安装并 (与您的配置配合使用)- 问题更少,比尝试更容易 和那个残废的码头一起工作 与GWT一起提供