Struts 2.3.1.2で404エラーが発生しました.


最近struts 2を勉強していますが、ずっと成功できません.最も簡単な例を使いました
src/struts.xml
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE struts PUBLIC "-//Apache Software 
Foundation//DTD Struts Configuration 2.0//EN"  
 "http://struts.apache.org/dtds/struts-2.0.dtd">
<struts>
	<include file="struts-default.xml" />
	<package name="bixy" namespace="/" extends="struts-default">
		<action name="hello" class="action.HelloStruts">
			<result name="suc">
				/hello.jsp
			</result>
			<result name="err">
				/error.jsp
			</result>
		</action>
	</package>
</struts> 

src/action/HelloStruts.java
package action;

import com.opensymphony.xwork2.ActionSupport;  
public class HelloStruts extends ActionSupport {  
    private String meg="hello,world!";  
    public String getMeg() {  
        return meg;  
    }  
    public void setMeg(String meg) {  
        this.meg = meg;  
    }  
@Override  
    public String execute() throws Exception {  
        String f="";  
        if("hello".equals(meg))  
        {  
            f="suc";  
        }else{  
            f="err";  
        }  
        return f;  
    }  
}  

WebContent/index.jsp
<%@ page language="java" pageEncoding="gbk"%>
<body>
	<form action="hello.action" method="post">
		name:<input name="meg" type="text"> <input type="submit"
			value="submit" />
	</form>
</body>

 WebContent/error.jsp
<%@ page language="java" pageEncoding="gbk"%>
<body>      !
</body>

 WebContent/hello.jsp
<%@ page language="java" pageEncoding="gbk"%>
<%@ taglib prefix="s" uri="/struts-tags"%><!--   struts2  -->
<body>
	      :
	<s:property value="meg" />
</body>

WebContent/WEB-INF/web.xml
<?xml version="1.0" encoding="UTF-8"?>
<web-app version="2.5" 
	xmlns="http://java.sun.com/xml/ns/javaee" 
	xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
	xsi:schemaLocation="http://java.sun.com/xml/ns/javaee 
	http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd">

    <!--FilterDispatcher  struts2-core.jar  --> 
    <filter> 
        <filter-name>struts2</filter-name> 
        <filter-class>org.apache.struts2.dispatcher.
    FilterDispatcher</filter-class> 
    </filter>   
    <filter-mapping> 
        <filter-name>struts2</filter-name> 
        <url-pattern>/*</url-pattern> 
    </filter-mapping> 
    <!--      --> 
    <welcome-file-list> 
        <welcome-file>index.jsp</welcome-file> 
    </welcome-file-list> 
	
</web-app>

 コンパイル、デプロイ後、
HTTP Status 404
 
The discussion:
Jeffsui回答于2012-04-12 08:06(昨日(8:06))
2.3のfilterはまた返しましたか?
view source print ?
<filter>
       <filter-name>struts2</filter-name>
       <filter-class>org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter</filter-class>
   </filter>

   <filter-mapping>
       <filter-name>struts2</filter-name>
       <url-pattern>/*</url-pattern>
   </filter-mapping>

これは2.1.8のfilter構成です.参考にしてください.
 
張培立は2012-04-12 08:25(昨日(8:25))に答えた.
2階に上がってみる
 
WebContent/index.jspのパスに問題があり、actionのパスが間違っています
  Jeffsui回答于2012-04-12 08:37(昨日(8:37))
1.導入時の起動情報を表示し、異常があるかどうかを確認する
2.インポートしたjarパッケージが完全かどうかを確認します.
3.パスが間違っていないか
 
 王振威は2012-04-12 08:47(昨日(8:47))に答えた.
tomcatの構成に問題があるのではないかと疑っています.まずservletを書いてみてください.
 
I post the error:
 
2012-4-12 9:05:57 com.opensymphony.xwork2.util.logging.commons.CommonsLogger error
  : Dispatcher initialization failed
Unable to load configuration. - bean - jar:file:/D:/test/TestStruts2/WebContent/WEB-INF/lib/struts2-core-2.3.1.2.jar!/struts-default.xml:54:89
    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.initFilter(ApplicationFilterConfig.java:277)
    at org.apache.catalina.core.ApplicationFilterConfig.getFilter(ApplicationFilterConfig.java:258)
    at org.apache.catalina.core.ApplicationFilterConfig.setFilterDef(ApplicationFilterConfig.java:382)
    at org.apache.catalina.core.ApplicationFilterConfig.<init>(ApplicationFilterConfig.java:103)
    at org.apache.catalina.core.StandardContext.filterStart(StandardContext.java:4638)
    at org.apache.catalina.core.StandardContext.startInternal(StandardContext.java:5294)
    at org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:150)
    at org.apache.catalina.core.ContainerBase$StartChild.call(ContainerBase.java:1566)
    at org.apache.catalina.core.ContainerBase$StartChild.call(ContainerBase.java:1556)
    at java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:303)
    at java.util.concurrent.FutureTask.run(FutureTask.java:138)
    at java.util.concurrent.ThreadPoolExecutor$Worker.runTask(ThreadPoolExecutor.java:886)
    at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:908)
    at java.lang.Thread.run(Thread.java:662)
Caused by: Unable to load bean: type: class:org.apache.struts2.views.freemarker.FreemarkerManager - bean - jar:file:/D:/test/TestStruts2/WebContent/WEB-INF/lib/struts2-core-2.3.1.2.jar!/struts-default.xml:54:89
    at com.opensymphony.xwork2.config.providers.XmlConfigurationProvider.register(XmlConfigurationProvider.java:235)
    at org.apache.struts2.config.StrutsXmlConfigurationProvider.register(StrutsXmlConfigurationProvider.java:102)
    at com.opensymphony.xwork2.config.impl.DefaultConfiguration.reloadContainer(DefaultConfiguration.java:180)
    at com.opensymphony.xwork2.config.ConfigurationManager.getConfiguration(ConfigurationManager.java:66)
    ... 18 more
Caused by: java.lang.NoClassDefFoundError: freemarker/template/TemplateException
    at java.lang.Class.getDeclaredConstructors0(Native Method)
    at java.lang.Class.privateGetDeclaredConstructors(Class.java:2389)
    at java.lang.Class.getDeclaredConstructors(Class.java:1836)
    at com.opensymphony.xwork2.config.providers.XmlConfigurationProvider.register(XmlConfigurationProvider.java:225)
    ... 21 more
Caused by: java.lang.ClassNotFoundException: freemarker.template.TemplateException
    at org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1701)
    at org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1546)
    ... 25 more
2012-4-12 9:05:57 org.apache.catalina.core.StandardContext startInternal
  : Error filterStart

 
MarkYao回答は2012-04-1209:19(昨日(9:19))
問題はここにあります.freemarker jarパッケージをインポートしていないでしょう.
Caused by: java.lang.NoClassDefFoundError: freemarker/template/TemplateException 
    at java.lang.Class.getDeclaredConstructors0(Native Method)      at java.lang.Class.privateGetDeclaredConstructors(Class.java:2389)      at java.lang.Class.getDeclaredConstructors(Class.java:1836)      at 
 
Jeffsui回答于2012-04-12 09:37(昨日(9:37))
「MarkYao」からの回答を引用
問題はここにあります.freemarker jarパッケージをインポートしていないでしょう.
Caused by: java.lang.NoClassDefFoundError: freemarker/template/TemplateException 
    at java.lang.Class.getDeclaredConstructors0(Native Method)      at java.lang.Class.privateGetDeclaredConstructors(Class.java:2389)      at java.lang.Class.getDeclaredConstructors(Class.java:1836)      at 
はい、この問題です.freemarker.jarはインポートしていません.
At last ,i solve the problem besause of the freemarker.jar and filter setting.
<filter>
       <filter-name>struts2</filter-name>
       <filter-class>org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter</filter-class>
   </filter>

   <filter-mapping>
       <filter-name>struts2</filter-name>
       <url-pattern>/*</url-pattern>
   </filter-mapping>