环境搭建
项目目录
导入依赖jar包,如上图lib目录所示。
不同的版本可能会不一样,没关系在tomcat启动时,如果报错java.lang.ClassNotFoundException,我们可以按照错误提示添加相应jar包。
在web.xml中配置struts2过滤器
将Struts2所带的过滤器org.apache.struts2.dispatcher.FilterDispatcher配置到工程的web.xml文件中,默认情况下,该过滤器拦截请求字符串中以.action结尾的请求,并将该请求委托给指定的Action进行处理。
在web.xml加入下面代码
<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>
注:可以在filter元素中加入<init-param>子元素来设定struts.xml配置文件的路径。若设置了<param-name>config</param-name>参数,那struts-default.xml等原来struts2默认加载的文件也要手动指定,否则不会自动加载。
struts-default.xml的路径在struts2-core-2.x.x jar包底下
编写一个struts小程序的步骤
1.创建一个类来存储欢迎消息(模型)
2.创建一个服务器页面呈现消息(视图)
3.创建一个页面提交用户请求参数(表单)
4.创建一个Action类来控制用户之间的互动,模型和视图(控制器)
5.创建一个映射(struts.xml)来描述Action类和视图的关系。
1.存储消息MessageStore.java
package hello; public class MessageStore {
private String message;
public MessageStore() { setMessage("Hello Struts User");
}
public String getMessage() { return message;
}
public void setMessage(String message) { this.message = message;
}
public String toString(){
return message;
} }
2.呈现消息Hello.jsp
在这里简单运用一些struts标签,取得action的属性值,简化信息的显示。在这之前,我们需要引入struts标签库
<%@ taglib prefix="s" uri="/struts-tags" %>
struts2属性标记为<s:property>,主要有下面一些用法。
1.显示Action中的属性值:<s:property value="属性名" />
2.显示字符串,使用单引号:<s:property value="'字符串'" />
3.显示默认值,Action中找不到指定的属性时,显示default属性的值:<s:property value="属性名" default="默认值" />
4.解析HTML字符串,escape默认值为true,直接输出字符串,escape设为false时,解析HTML字符串:<s:property value="'<font color=\"red\">Red</font>'" escape="false" />
<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
<%@ taglib prefix="s" uri="/struts-tags" %>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<title>Hello World!</title>
</head>
<body>
<h2><s:property value="MessageStore" /> ${sessionScope.user}</p></h2>
<p>Number of visit this site: <s:property value="helloCount" /> times!</p>
</body>
</html>
3.提交请求index.jsp
<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
<%@ taglib prefix="s" uri="/struts-tags" %>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<title>Basic Struts 2 Application - Welcome</title>
</head>
<body>
<h1>Welcome To Struts 2!</h1>
<s:form action="hello">
<s:textfield name="user" label="userName"/>
<s:submit value="提交"></s:submit>
</s:form>
</body>
</html>
4.处理用户请求HelloAction.java
HelloAction继承ActionSupport,充当控制器的角色,用于:
1.接受用户的请求参数
2.处理用户请求(或者调用逻辑处理)
3.返回String类型的结果,告诉Struts要呈现什么的视图。
接受请求参数
在action中设置参数属性,添加getter和setter方法,让action自动填充,并做恰当的类型转化。
处理请求
我们可以在execute方法中处理用户的请求,直接进行处理请求参数或者调用service的方法。该方法有一个String类型的返回值,告诉Struts应该将什么视图返回给用户。
package hello; import com.opensymphony.xwork2.ActionContext;
import com.opensymphony.xwork2.ActionSupport; public class HelloAction extends ActionSupport { private static final long serialVersionUID = 1L;
private static int helloCount = 0;
private MessageStore messageStore;
private String user;
public String execute() throws Exception {
messageStore = new MessageStore() ;
helloCount++;
ActionContext.getContext().getSession().put("user", user);
return SUCCESS;
} public MessageStore getMessageStore() {
return messageStore;
} public void setMessageStore(MessageStore messageStore) {
this.messageStore = messageStore;
} public String getUser() {
return user;
} public void setUser(String user) {
this.user = user;
} public int getHelloCount() {
return helloCount;
} public void setHelloCount(int helloCount) {
this.helloCount = helloCount;
}
}
5.struts.xml配置
我们将在struts.xml定义处理结果字符串和资源之间的映射关系,即定义action的execute方法返回的字符串所对应的视图。
在工程类路径下创建struts.xml文件,这是Struts2的配置文件,在struts.xml文件中可以配置Action、Bean、Interceptor等组件。
<?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>
<constant name="struts.devMode" value="true" />
<package name="basicstruts2" extends="struts-default">
<action name="hello" class="hello.HelloAction" method="execute">
<result name="success">/Hello.jsp</result>
</action>
</package>
</struts>
注:WEB应用程序的类路径是指WEB-INF/classes目录,在Eclipse中,创建在src目录下的文件最终发布后会自动复制到WEB-INF/classes目录下。
代码清单3中涉及到很多标签,以下是简单的解释:
标签名称 |
说明 |
include |
包含其他xml文件,在示例中,这意味着struts.xml可以访问定义在struts-default.xml文件中的组件。 该元素可以使得Struts2定义多个配置文件,“分而治之”。 要注意的是,任何一个struts2配置文件都应该和struts.xml有相同的格式,包括doctype,并且可以放在类路径下的任何地方。 |
package |
为Action或截拦器分组。 name:名称,必填项,名称自定义,但不能相同。方便别的package引用。 extends:package能继承其他的package,即通过该属性实现,值为另一个package的name。 在示例中,extends =”struts-default”是从struts-default.xml中继承的。 |
action |
定义Action,name属性为访问时用到的名称,class属性是Action的类名。 |
result |
根据Action的返回值定义页面导航。 Action的预定义的返回值有: String SUCCESS = "success"; String NONE = "none"; String ERROR = "error"; String INPUT = "input"; String LOGIN = "login"; 比如,当Action返回SUCCESS时希望转到ok.jsp页面,则可以这样写: <result name="success">ok.jsp</result> 其中,name的缺省为success。 |
源码下载
我已经将工程代码打包(lib下没有导入jar包)