Struts 2.3.1.2で404エラーが発生しました.
最近struts 2を勉強していますが、ずっと成功できません.最も簡単な例を使いました
src/struts.xml
src/action/HelloStruts.java
WebContent/index.jsp
WebContent/error.jsp
WebContent/hello.jsp
WebContent/WEB-INF/web.xml
コンパイル、デプロイ後、
HTTP Status 404
The discussion:
Jeffsui回答于2012-04-12 08:06(昨日(8:06))
2.3のfilterはまた返しましたか?
view source print ?
これは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:
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.
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>