2013-03-14 4 views
2

나는 struts.xml에 패키지를 선언했습니다. 하지만 Tomcat6은 내가 추가 한 이후로 시작할 수 없습니다. struts.xml의 구성은 다음과 같습니다struts 2 패키지가 "struts-default"를 확장해야합니까?

INFO: Choosing bean (struts) for interface org.apache.struts2.dispatcher.StaticContentLoader 
三月 14, 2013 10:07:52 下午 com.opensymphony.xwork2.util.logging.jdk.JdkLogger info 
INFO: Choosing bean (struts) for interface com.opensymphony.xwork2.UnknownHandlerManager 
三月 14, 2013 10:07:53 下午 com.opensymphony.xwork2.util.logging.jdk.JdkLogger error 
SEVERE: Dispatcher initialization failed 
Unable to load configuration. - result - file:/C:/tomcat6/webapps/sstart/WEB-INF/classes/struts.xml:57:27 
    at com.opensymphony.xwork2.config.ConfigurationManager.getConfiguration(ConfigurationManager.java:69) 
    at org.apache.struts2.dispatcher.Dispatcher.init_PreloadConfiguration(Dispatcher.java:390) 
    at org.apache.struts2.dispatcher.Dispatcher.init(Dispatcher.java:436) 
    at org.apache.struts2.dispatcher.ng.InitOperations.initDispatcher(InitOperations.java:69) 
    at org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter.init(StrutsPrepareAndExecuteFilter.java:51) 
    at org.apache.catalina.core.ApplicationFilterConfig.getFilter(ApplicationFilterConfig.java:295) 
    at org.apache.catalina.core.ApplicationFilterConfig.setFilterDef(ApplicationFilterConfig.java:422) 
    at org.apache.catalina.core.ApplicationFilterConfig.<init>(ApplicationFilterConfig.java:115) 
    at org.apache.catalina.core.StandardContext.filterStart(StandardContext.java:4072) 
    at org.apache.catalina.core.StandardContext.start(StandardContext.java:4726) 
    at org.apache.catalina.core.ContainerBase.addChildInternal(ContainerBase.java:799) 
    at org.apache.catalina.core.ContainerBase.addChild(ContainerBase.java:779) 
    at org.apache.catalina.core.StandardHost.addChild(StandardHost.java:601) 
    at org.apache.catalina.startup.HostConfig.deployDirectory(HostConfig.java:1079) 
    at org.apache.catalina.startup.HostConfig.deployDirectories(HostConfig.java:1002) 
    at org.apache.catalina.startup.HostConfig.deployApps(HostConfig.java:506) 
    at org.apache.catalina.startup.HostConfig.start(HostConfig.java:1317) 
    at org.apache.catalina.startup.HostConfig.lifecycleEvent(HostConfig.java:324) 
    at org.apache.catalina.util.LifecycleSupport.fireLifecycleEvent(LifecycleSupport.java:142) 
    at org.apache.catalina.core.ContainerBase.start(ContainerBase.java:1065) 
    at org.apache.catalina.core.StandardHost.start(StandardHost.java:840) 
    at org.apache.catalina.core.ContainerBase.start(ContainerBase.java:1057) 
    at org.apache.catalina.core.StandardEngine.start(StandardEngine.java:463) 
    at org.apache.catalina.core.StandardService.start(StandardService.java:525) 
    at org.apache.catalina.core.StandardServer.start(StandardServer.java:754) 
    at org.apache.catalina.startup.Catalina.start(Catalina.java:595) 
    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:601) 
    at org.apache.catalina.startup.Bootstrap.start(Bootstrap.java:289) 
    at org.apache.catalina.startup.Bootstrap.main(Bootstrap.java:414) 
Caused by: No result type specified for result named 'success', perhaps the parent package does not specify the result type? - result - file:/C:/tomcat6/webapps/sstart/WEB-INF/classes/struts.xml:57:27 
    at com.opensymphony.xwork2.config.providers.XmlConfigurationProvider.buildResults(XmlConfigurationProvider.java:636) 
    at com.opensymphony.xwork2.config.providers.XmlConfigurationProvider.loadGlobalResults(XmlConfigurationProvider.java:807) 
    at com.opensymphony.xwork2.config.providers.XmlConfigurationProvider.addPackage(XmlConfigurationProvider.java:477) 
    at com.opensymphony.xwork2.config.providers.XmlConfigurationProvider.loadPackages(XmlConfigurationProvider.java:278) 
    at org.apache.struts2.config.StrutsXmlConfigurationProvider.loadPackages(StrutsXmlConfigurationProvider.java:112) 
    at com.opensymphony.xwork2.config.impl.DefaultConfiguration.reloadContainer(DefaultConfiguration.java:204) 
    at com.opensymphony.xwork2.config.ConfigurationManager.getConfiguration(ConfigurationManager.java:66) 
    ... 31 more 

三月 14, 2013 10:07:53 下午 org.apache.catalina.core.StandardContext start 
SEVERE: Error filterStart 
三月 14, 2013 10:07:53 下午 org.apache.catalina.core.StandardContext start 
SEVERE: Context [/sstart] startup failed due to previous errors 
三月 14, 2013 10:07:53 下午 org.apache.catalina.loader.WebappClassLoader clearThreadLocalMap 

내가 추가되면이

<package name="pkg2" namespace="/0314" extends='struts-default'> 

<interceptors> 
    <interceptor name="myInterceptor" class="com.chailie.test4.MyInterceptor"/> 
    <interceptor-stack name="myInterceptorStack"> 
     <interceptor-ref name="myInterceptor"/> 
    </interceptor-stack> 
</interceptors> 
<global-results> 
    <result name="success">/success.jsp</result> 
</global-results> 
<action name="test1" class="com.chailie.test4.HelloWorld1">   
    <result name="success">/success.jsp</result> 
    <interceptor-ref name="myInterceptorStack"/> 
</action> 
</package> 

는 AS 패키지 = '스트럿 기본을'확장 :

<package name="pkg2" namespace="/0314"> 

    <interceptors> 
     <interceptor name="myInterceptor" class="com.chailie.test4.MyInterceptor"/> 
     <interceptor-stack name="myInterceptorStack"> 
      <interceptor-ref name="myInterceptor"/> 
     </interceptor-stack> 
    </interceptors> 
    <global-results> 
     <result name="success">/success.jsp</result> 
    </global-results> 
    <action name="test1" class="com.chailie.test4.HelloWorld1">   
     <result name="success">/success.jsp</result> 
     <interceptor-ref name="myInterceptorStack"/> 
    </action> 
</package> 

예외의 스택 트레이스이었다 tomcat6 내가 부팅 할 때 tomcat6 제대로 시작할 수 있습니다.

내 질문은 하나의 "패키지"를 struts.xml에 추가 할 때입니다. 패키지가 "struts-default"패키지에서 확장되어야합니까? 내가 봤지만, "확장"속성은 패키지 요소의 옵션 속성에 불과합니다. 그럼 왜이 문제가 생길까요?

답변

4

원래의 strus-default.xml을 확인하면 모든 기본 인터셉터와 결과가 정의되어있는 것을 볼 수 있습니다. 결과를 정의하지 않는다면 실패 할 가능성이 큽니다. 지금은 테스트 할 수 없지만 디스패처 결과 및 기본 클래스 참조에 대한 정의를 추가하면 확장하지 않고 시작해야한다고 가정합니다.

<result-types> 
    <result-type name="dispatcher" class="org.apache.struts2.dispatcher.ServletDispatcherResult" default="true"/> 
</result-types> 


<default-class-ref class="com.opensymphony.xwork2.ActionSupport" /> 
+0

+1 좋은 설명 –