1

我创建了一个ejb远程接口,将其部署在应用程序服务器上的本地计算机上glassfish,并且运行良好,但是在远程服务器上对其进行测试时,它已成功部署,但是在验证登录表单时我无法访问远程方法,并出现以下错误:

javax.ejb.EJBException

在 com.sun.ejb.containers.BaseContainer.processSystemException(BaseContainer.java:5215)

在 com.sun.ejb.containers.BaseContainer.completeNewTx(BaseContainer.java:5113)

在 com.sun.ejb.containers.BaseContainer.postInvokeTx(BaseContainer.java:4901)

在 com.sun.ejb.containers.BaseContainer.postInvoke(BaseContainer.java:2045)

在 com.sun.ejb.containers.BaseContainer.postInvoke(BaseContainer.java:1994)

在 com.sun.ejb.containers.EJBLocalObjectInvocationHandler.invoke(EJBLocalObjectInvocationHandl er.java:222)

在 com.sun.ejb.containers.EJBLocalObjectInvocationHandlerDelegate.invoke(EJBLocalObjectInvocat ionHandlerDelegate.java:89) 在 $Proxy206.findStudentByFirstName(未知来源)

在 pac.Serve.processRequest(Serve.java:46) 在 pac.Serve.doPost(Serve.java:124)

在 javax.servlet.http.HttpServlet.service(HttpServlet.java:688)

在 javax.servlet.http.HttpServlet.service(HttpServlet.java:770)

在 org.apache.catalina.core.StandardWrapper.service(StandardWrapper.java:1550)

在 org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:281)

在 org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:175)

在 org.apache.catalina.core.StandardPipeline.doInvoke(StandardPipeline.java:655)

在 org.apache.catalina.core.StandardPipeline.invoke(StandardPipeline.java:595)

在 org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:161)

在 org.apache.catalina.connector.CoyoteAdapter.doService(CoyoteAdapter.java:331)

在 org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:231)

在 com.sun.enterprise.v3.services.impl.ContainerMapper$AdapterCallable.call(ContainerMapper.java:317)

在 com.sun.enterprise.v3.services.impl.ContainerMapper.service(ContainerMapper.java:195)

在 com.sun.grizzly.http.ProcessorTask.invokeAdapter(ProcessorTask.java:860)

在 com.sun.grizzly.http.ProcessorTask.doProcess(ProcessorTask.java:757)

在 com.sun.grizzly.http.ProcessorTask.process(ProcessorTask.java:1056)

在 com.sun.grizzly.http.DefaultProtocolFilter.execute(DefaultProtocolFilter.java:229)

在 com.sun.grizzly.DefaultProtocolChain.executeProtocolFilter(DefaultProtocolChain.java:137)

在 com.sun.grizzly.DefaultProtocolChain.execute(DefaultProtocolChain.java:104)

在 com.sun.grizzly.DefaultProtocolChain.execute(DefaultProtocolChain.java:90)

在 com.sun.grizzly.http.HttpProtocolChain.execute(HttpProtocolChain.java:79)

在 com.sun.grizzly.ProtocolChainContextTask.doCall(ProtocolChainContextTask.java:54)

在 com.sun.grizzly.SelectionKeyContextTask.call(SelectionKeyContextTask.java:59)

在 com.sun.grizzly.ContextTask.run(ContextTask.java:71)

在 com.sun.grizzly.util.AbstractThreadPool$Worker.doWork(AbstractThreadPool.java:532)

在 com.sun.grizzly.util.AbstractThreadPool$Worker.run(AbstractThreadPool.java:513)

在 java.lang.Thread.run(Thread.java:722) 引起:异常 [EclipseLink-4002] (Eclipse Persistence Services - 2.3.2.v20111125-r10461):org.eclipse.persistence.exceptions.DatabaseException 内部异常: com.mysql.jdbc.exceptions.MySQLSyntaxErrorException:表'schooldb.Jss_Student_Details'不存在错误代码:1146调用:从schooldb.Jss_Student_Details选择名字,姓氏在哪里(电子邮件=?)绑定=> [1参数绑定]查询: ReportQuery(name="JssStudentDetails.findByEmail1" referenceClass=JssStudentDetails sql="SELECT firstName, lastName FROM schooldb.Jss_Student_Details WHERE (email = ?)")

在 org.eclipse.persistence.exceptions.DatabaseException.sqlException(DatabaseException.java:333)

在 org.eclipse.persistence.internal.databaseaccess.DatabaseAccessor.basicExecuteCall(DatabaseAccessor.java:644)

在 org.eclipse.persistence.internal.databaseaccess.DatabaseAccessor.executeCall(DatabaseAccessor.java:535)

在 org.eclipse.persistence.internal.sessions.AbstractSession.basicExecuteCall(AbstractSession.java:1717)

在 org.eclipse.persistence.sessions.server.ServerSession.executeCall(ServerSession.java:566)

在 org.eclipse.persistence.internal.queries.DatasourceCallQueryMechanism.executeCall(DatasourceCallQueryMechanism.java:207)

在 org.eclipse.persistence.internal.queries.DatasourceCallQueryMechanism.executeCall(DatasourceCallQueryMechanism.java:193)

在 org.eclipse.persistence.internal.queries.DatasourceCallQueryMechanism.executeSelectCall(DatasourceCallQueryMechanism.java:264)

在 org.eclipse.persistence.internal.queries.DatasourceCallQueryMechanism.selectAllRows(DatasourceCallQueryMechanism.java:646)

在 org.eclipse.persistence.internal.queries.ExpressionQueryMechanism.selectAllRowsFromTable(ExpressionQueryMechanism.java:2611)

在 org.eclipse.persistence.internal.queries.ExpressionQueryMechanism.selectAllReportQueryRows(ExpressionQueryMechanism.java:2554)

在 org.eclipse.persistence.queries.ReportQuery.executeDatabaseQuery(ReportQuery.java:846)

在 org.eclipse.persistence.queries.DatabaseQuery.execute(DatabaseQuery.java:844)

在 org.eclipse.persistence.queries.ObjectLevelReadQuery.execute(ObjectLevelReadQuery.java:1040)

在 org.eclipse.persistence.queries.ReadAllQuery.execute(ReadAllQuery.java:392)

在 org.eclipse.persistence.queries.ObjectLevelReadQuery.executeInUnitOfWork(ObjectLevelReadQuery.java:1128)

在 org.eclipse.persistence.internal.sessions.UnitOfWorkImpl.internalExecuteQuery(UnitOfWorkImpl.java:2871)

在 org.eclipse.persistence.internal.sessions.AbstractSession.executeQuery(AbstractSession.java:1516)

在 org.eclipse.persistence.internal.sessions.AbstractSession.executeQuery(AbstractSession.java:1498)

在 org.eclipse.persistence.internal.sessions.AbstractSession.executeQuery(AbstractSession.java:1463)

在 org.eclipse.persistence.internal.jpa.EJBQueryImpl.executeReadQuery(EJBQueryImpl.java:485)

在 org.eclipse.persistence.internal.jpa.EJBQueryImpl.getResultList(EJBQueryImpl.java:742)

在 wak.capableDoa.findStudentByFirstName(capableDoa.java:34)

在 sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)

在 sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)

在 sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)

在 java.lang.reflect.Method.invoke(Method.java:601)

在 org.glassfish.ejb.security.application.EJBSecurityManager.runMethod(EJBSecurityManager.java:1052)

在 org.glassfish.ejb.security.application.EJBSecurityManager.invoke(EJBSecurityManager.java:1124)

在 com.sun.ejb.containers.BaseContainer.invokeBeanMethod(BaseContainer.java:5388)

在 com.sun.ejb.EjbInvocation.invokeBeanMethod(EjbInvocation.java:619)

在 com.sun.ejb.EjbInvocation.proceed(EjbInvocation.java:571) 的 com.sun.ejb.containers.interceptors.AroundInvokeChainImpl.invokeNext(InterceptorManager.java:800)

在 org.jboss.weld.ejb.SessionBeanInterceptor.aroundInvoke(SessionBeanInterceptor.java:42)

在 sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)

在 sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)

在 sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)

在 java.lang.reflect.Method.invoke(Method.java:601)

在 com.sun.ejb.containers.interceptors.AroundInvokeInterceptor.intercept(InterceptorManager.java:861)

在 com.sun.ejb.EjbInvocation.proceed(EjbInvocation.java:571) 的 com.sun.ejb.containers.interceptors.AroundInvokeChainImpl.invokeNext(InterceptorManager.java:800)

在 com.sun.ejb.containers.interceptors.SystemInterceptorProxy.doAround(SystemInterceptorProxy.java:162)

在 com.sun.ejb.containers.interceptors.SystemInterceptorProxy.aroundInvoke(SystemInterceptorProxy.java:144) 在 sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)

在 sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)

在 sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)

在 java.lang.reflect.Method.invoke(Method.java:601)

在 com.sun.ejb.containers.interceptors.AroundInvokeInterceptor.intercept(InterceptorManager.java:861)

在 com.sun.ejb.containers.interceptors.AroundInvokeChainImpl.invokeNext(InterceptorManager.java:800)

在 com.sun.ejb.containers.interceptors.InterceptorManager.intercept(InterceptorManager.java:370) 在 com.sun.ejb.containers.BaseContainer.__intercept(BaseContainer.java:5360)

在 com.sun.ejb.containers.BaseContainer.intercept(BaseContainer.java:5348)

在 com.sun.ejb.containers.EJBLocalObjectInvocationHandler.invoke(EJBLocalObjectInvocationHandler.java:214) ... 30 更多原因:com.mysql.jdbc.exceptions.MySQLSyntaxErrorException:表 'schooldb.Jss_Student_Details' 不存在

在 com.mysql.jdbc.SQLError.createSQLException(SQLError.java:936)

在 com.mysql.jdbc.MysqlIO.checkErrorPacket(MysqlIO.java:2985)

在 com.mysql.jdbc.MysqlIO.sendCommand(MysqlIO.java:1631)

在 com.mysql.jdbc.MysqlIO.sqlQueryDirect(MysqlIO.java:1723)

在 com.mysql.jdbc.Connection.execSQL(Connection.java:3283)

在 com.mysql.jdbc.PreparedStatement.executeInternal(PreparedStatement.java:1332)

在 com.mysql.jdbc.PreparedStatement.executeQuery(PreparedStatement.java:1467)

在 com.sun.gjc.spi.jdbc40.PreparedStatementWrapper40.executeQuery(PreparedStatementWrapper40.java:642)

在 org.eclipse.persistence.internal.databaseaccess.DatabaseAccessor.executeSelect(DatabaseAccessor.java:931)

在 org.eclipse.persistence.internal.databaseaccess.DatabaseAccessor.basicExecuteCall(DatabaseAccessor.java:607) ... 81 更多

请有人帮助解决此错误,在此先感谢。

4

1 回答 1

1

这与远程/本地 ejb 无关......这是一个 SQL 错误:

com.mysql.jdbc.exceptions.MySQLSyntaxErrorException: Table 'schooldb.Jss_Student_Details'     doesn't exist
于 2013-05-27T16:28:58.007 回答