【问题标题】:Struts 2 annotation error when calling action调用动作时Struts 2注释错误
【发布时间】:2014-07-18 13:52:52
【问题描述】:

大家好,我在使用 Struts 2 Annotated Actions 时遇到问题

在我的pom.xml 我有:

<!-- STRUTS2 annotation -->
<dependency>
    <groupId>org.apache.struts</groupId>
    <artifactId>struts2-convention-plugin</artifactId>
    <version>2.3.16.3</version>
</dependency>

<!-- STRUTS2 SPRING integration -->
<dependency>
    <groupId>org.apache.struts</groupId>
    <artifactId>struts2-spring-plugin</artifactId>
    <version>2.3.15.1</version>
</dependency> 

在我的web.xml

<filter>
  <filter-name>struts2</filter-name>
    <filter-class>com.agiletec.apsadmin.system.dispatcher.StrutsPrepareAndExecuteFilter</filter-class>
      <init-param>
      <param-name>struts.devMode</param-name>
      <param-value>true</param-value>        
      </init-param>
      <init-param>
      <param-name>struts.objectFactory</param-name>
      <param-value>spring</param-value>        
      </init-param>        
<init-param>
    <param-name>actionPackages</param-name>
    <param-value>it.aicof.projects.openMED.aps.internalservlet.actions</param-value>
</init-param>          
</filter>  
  
<filter-mapping>
    <filter-name>struts2</filter-name>
    <url-pattern>/do/*</url-pattern>
</filter-mapping>
<filter-mapping>
        <filter-name>struts2</filter-name>
        <url-pattern>/struts/*</url-pattern>
</filter-mapping>

我有两个动作类:

@Namespace("/budget")
@SuppressWarnings("serial")
public class BudgetAction extends BaseAction {
    
    @Action(value = "/start", results = { @Result(name = "success", location = "/WEB-INF/openmed/aps/jsp/internalservlet/budget/budget.jsp") })
    public String start(){
.......


@Namespace("/upload")
@SuppressWarnings("serial")
public class UploadAction extends BaseAction {

    @Action(value = "/init", results = {
        @Result(name = "success", location = "/WEB-INF/openmed/aps/jsp/internalservlet/upload/upload.jsp")})
    public String init() {
        .....

如果我打电话给第一个 http://localhost:8080/openMED/do/budget/start.action 一切正常 但是当我打电话给第二个http://localhost:8080/openMED/do/upload/init.action 时,我得到了这个错误

 There is no Action mapped for namespace [/do] and action name [init] associated with context path [/openMED]. - [unknown location]

    com.opensymphony.xwork2.DefaultActionProxy.prepare(DefaultActionProxy.java:185)
    org.apache.struts2.impl.StrutsActionProxy.prepare(StrutsActionProxy.java:63)
    org.apache.struts2.impl.StrutsActionProxyFactory.createActionProxy(StrutsActionProxyFactory.java:39)
    com.opensymphony.xwork2.DefaultActionProxyFactory.createActionProxy(DefaultActionProxyFactory.java:58)
    org.apache.struts2.dispatcher.Dispatcher.serviceAction(Dispatcher.java:553)
    org.apache.struts2.dispatcher.ng.ExecuteOperations.executeAction(ExecuteOperations.java:77)
    org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter.doFilter(StrutsPrepareAndExecuteFilter.java:99)
    org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:243)
    org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:210)
    org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:224)
    org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:169)
    org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:472)
    org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:168)
    org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:98)
    org.apache.catalina.valves.AccessLogValve.invoke(AccessLogValve.java:927)
    org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:118)
    org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:407)
    org.apache.coyote.http11.AbstractHttp11Processor.process(AbstractHttp11Processor.java:987)
    org.apache.coyote.AbstractProtocol$AbstractConnectionHandler.process(AbstractProtocol.java:579)
    org.apache.tomcat.util.net.JIoEndpoint$SocketProcessor.run(JIoEndpoint.java:309)
    java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1145)
    java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:615)
    java.lang.Thread.run(Thread.java:744)

怎么了?两个类的配置方式相同。

【问题讨论】:

    标签: java spring struts2 struts2-convention-plugin action-mapping


    【解决方案1】:

    根据错误提示

    2014-07-18 15:49:15,454 - 错误 - 调度程序 - 处理请求期间发生异常:没有为命名空间 [/do] 映射的操作和与上下文路径 [/openMED] 关联的操作名称 [init]。 - [未知位置]。

    您使用了 url /openMED/do/upload/init.action,但您的操作已映射到命名空间 /upload。命名空间是从上下文路径到操作名称的路径。您可以找到有关namespace configuration 的更多信息。您还可以查看 this 示例以更好地理解命名空间概念。

    你应该改变动作映射

    @Namespace("/do/upload")
    @SuppressWarnings("serial")
    public class UploadAction extends BaseAction {
    
    @Action(value = "init", results = {@Result(name = "success", location = "/WEB-INF/openmed/aps/jsp/internalservlet/upload/upload.jsp")})
    public String init() {
    

    【讨论】:

    • Roman..我意识到问题不是我想...所以我改变了问题以尝试更具体
    • 更新到你的变化。
    • 好的,但另一个是 /openMED/do/budget/start.action 与 /openMED/do/upload/init.action 相同的模式 .... 它工作正常。那么..为什么第一个有效而另一个无效?
    • 您可能还有其他操作映射。你没有发帖struts.xml
    • 我没有 struts.xml....也许我发现了问题,这是我的错误。我将 web.xml 中的动作路径映射为it.aicof.projects.openMED.aps.internalservlet.actions,但不工作的动作在路径it.aicof.projects.openMED.aps.internalservlet 中,因此它不被 struts 识别为动作。我会尽量把它移到正确的道路上
    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2013-08-26
    • 2013-07-23
    • 2012-02-15
    • 2013-09-06
    相关资源
    最近更新 更多