Warning: file_get_contents(/data/phpspider/zhask/data//catemap/9/java/375.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Java Play Framewok 1.X-部署到Tomcat时出错-Can';找不到路由/控制器_Java_Tomcat_Playframework_Tomcat7_Playframework 1.x - Fatal编程技术网

Java Play Framewok 1.X-部署到Tomcat时出错-Can';找不到路由/控制器

Java Play Framewok 1.X-部署到Tomcat时出错-Can';找不到路由/控制器,java,tomcat,playframework,tomcat7,playframework-1.x,Java,Tomcat,Playframework,Tomcat7,Playframework 1.x,好的-新游戏!框架我的项目在内置播放服务器上运行良好。我试图将同一个项目部署到运行Tomcat 7的服务器上,但在catalina.out日志中发现以下错误: @6fn1ak9n6 Application.index action not found Action not found Action Application.index could not be found. Error raised is Controller controllers.Application not found

好的-新游戏!框架我的项目在内置播放服务器上运行良好。我试图将同一个项目部署到运行Tomcat 7的服务器上,但在catalina.out日志中发现以下错误:

@6fn1ak9n6
Application.index action not found

Action not found
Action Application.index could not be found. Error raised is Controller controllers.Application not found

play.exceptions.ActionNotFoundException: Action Application.index not found
        at play.mvc.ActionInvoker.getActionMethod(ActionInvoker.java:599)
        at play.mvc.ActionInvoker.resolve(ActionInvoker.java:85)
        at play.server.ServletWrapper$ServletInvocation.getInvocationContext(ServletWrapper.java:567)
        at play.Invoker$Invocation.init(Invoker.java:205)
        at play.Invoker$DirectInvocation.init(Invoker.java:305)
        at play.server.ServletWrapper$ServletInvocation.init(ServletWrapper.java:535)
        at play.Invoker$Invocation.run(Invoker.java:276)
        at play.server.ServletWrapper$ServletInvocation.run(ServletWrapper.java:552)
        at play.Invoker.invokeInThread(Invoker.java:68)
        at play.server.ServletWrapper.service(ServletWrapper.java:143)
        at javax.servlet.http.HttpServlet.service(HttpServlet.java:728)
        at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:305)
        at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:210)
        at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:222)
        at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:123)
        at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:472)
        at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:171)
        at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:99)
        at org.apache.catalina.valves.AccessLogValve.invoke(AccessLogValve.java:936)
        at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:118)
        at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:407)
        at org.apache.coyote.http11.AbstractHttp11Processor.process(AbstractHttp11Processor.java:1004)
        at org.apache.coyote.AbstractProtocol$AbstractConnectionHandler.process(AbstractProtocol.java:589)
        at org.apache.tomcat.util.net.JIoEndpoint$SocketProcessor.run(JIoEndpoint.java:310)
        at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1110)
        at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:603)
        at java.lang.Thread.run(Thread.java:679)
Caused by: java.lang.Exception: Controller controllers.Application not found
        ... 27 more
13:17:13,090 WARN  ~ 404 -> GET /tradjenta/ (Application.index action not found)
13:17:13,093 ERROR ~

@6fn1ak9n9
Internal Server Error (500)

No route found (In /app/views/errors/404.html around line 5)
No route able to invoke action Application.index was found.

play.exceptions.NoRouteFoundException: No route found
        at play.templates.BaseTemplate.throwException(BaseTemplate.java:82)
        at play.templates.GroovyTemplate.internalRender(GroovyTemplate.java:257)
        at play.templates.Template.render(Template.java:26)
        at play.templates.GroovyTemplate.render(GroovyTemplate.java:202)
        at play.server.ServletWrapper.serve404(ServletWrapper.java:373)
        at play.server.ServletWrapper$ServletInvocation.init(ServletWrapper.java:537)
        at play.Invoker$Invocation.run(Invoker.java:276)
        at play.server.ServletWrapper$ServletInvocation.run(ServletWrapper.java:552)
        at play.Invoker.invokeInThread(Invoker.java:68)
        at play.server.ServletWrapper.service(ServletWrapper.java:143)
        at javax.servlet.http.HttpServlet.service(HttpServlet.java:728)
        at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:305)
        at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:210)
        at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:222)
        at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:123)
        at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:472)
        at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:171)
        at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:99)
        at org.apache.catalina.valves.AccessLogValve.invoke(AccessLogValve.java:936)
        at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:118)
        at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:407)
        at org.apache.coyote.http11.AbstractHttp11Processor.process(AbstractHttp11Processor.java:1004)
        at org.apache.coyote.AbstractProtocol$AbstractConnectionHandler.process(AbstractProtocol.java:589)
        at org.apache.tomcat.util.net.JIoEndpoint$SocketProcessor.run(JIoEndpoint.java:310)
        at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1110)
        at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:603)
        at java.lang.Thread.run(Thread.java:679)
我的web.xml文件如下所示:

<?xml version="1.0" ?>
<web-app xmlns="http://java.sun.com/xml/ns/j2ee"
        xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
        xsi:schemaLocation="http://java.sun.com/xml/ns/j2ee http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd"
        version="2.4">

  <display-name>Play! (MyApp)</display-name>

  <context-param>
    <param-name>play.id</param-name>
    <param-value>war</param-value>
  </context-param>

  <listener>
      <listener-class>play.server.ServletWrapper</listener-class>
  </listener>

  <servlet>
    <servlet-name>play</servlet-name>
    <servlet-class>play.server.ServletWrapper</servlet-class>   
  </servlet>

  <servlet-mapping>
    <servlet-name>play</servlet-name>
    <url-pattern>/</url-pattern>
  </servlet-mapping>

</web-app>

玩(MyApp)
play.id
战争
play.server.ServletWrapper
玩
play.server.ServletWrapper
玩
/

为什么这些路由在Play服务器中运行良好,但在Tomcat中却不行?我需要在web.xml文件中声明conf/routes文件吗?

为什么要编写
web.xml
?你应该把你的申请打包,就这样。是的,正是我在做的。这只是运行play war创建的默认web.xml。我想这会对我的问题有所帮助。您是否尝试将应用程序部署为ROOT用户?