Struts 2开发基本流程

Struts 2工作流程

Struts2是一个基于MVC设计模式的Web开发框架, 正如官网上介绍的那样:

ApacheStruts 2 is an elegant, extensible framework for creating enterprise-ready Javaweb applications. The framework is designed to streamline the full developmentcycle, from building, to deploying, to maintaining applications over time.

Struts2是由Struts和Webwork这两个优秀的框架演化而来,它的出现解决了表现层和业务逻辑层紧耦合的问题。


为了支持Struts 2,通常我们需要添加以下类库:

  • commons-fileupload.jar            文件上传
  • commons-io.jar        I/O类库
  • commons-lang-2.4.jar     Java.lang包
  • commons-lang3-3.1.jar   Java lang包扩展
  • commons-logging.jar       日志
  • freemarker-2.3.19.jar      表现层框架
  • javassist-3.9.0.GA.jar      代码生成工具Hibernate用它在运行时扩展java类和实现,同cglib包
  • ognl-3.0.6.jar            对象图导航语言
  • struts2-core-2.3.14.2.jar                   Struts2核心组件
  • struts2-json-plugin-2.3.14.2.jar       Struts2对Json数据格式支持(非必须)
  • xwork-core-2.3.14.2.jar            webwork核心类库

接下来编辑Web应用中的web.xml,配置Struts2的核心类库,下面是配置文件的代码片段,在web.xml文件中,定义了框架的拦截器FilterDispatcher,Servlet初始化Struts框架并且处理所有请求。“/*”表示对于所有的请求都允许。

<?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">

	<filter>
		<!-- 定义Struts2的核心Filter -->
		<filter-name>struts2</filter-name>
		<filter-class>org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter</filter-class>
		<init-param>
			<param-name>actionPackages</param-name>
			<param-value>com.mycompany.myapp.actions</param-value>
		</init-param>
	</filter>
	<!-- 让struts2的核心Filter拦截所有的请求 -->
	<filter-mapping>
		<filter-name>struts2</filter-name>
		<url-pattern>/*</url-pattern>
	</filter-mapping>
	<!-- web应用的默认首页 -->
	<welcome-file-list>
		<welcome-file>index.jsp</welcome-file>
	</welcome-file-list>
</web-app>

Jsp页面(welcome.jsp和error.jsp省略):login.jsp

<%@ page language="java" import="java.util.*" pageEncoding="utf-8"%>
<%@taglib prefix="s" uri="/struts-tags"%>
<body>
<s:form action="login.action">
			<s:textfield name="username" key="user"></s:textfield>
			<s:textfield name="password" key="pass"></s:textfield>
<s:submit key="login"></s:submit>
</s:form>
</body>

Action类:

import com.opensymphony.xwork2.ActionContext;
import com.opensymphony.xwork2.ActionSupport;

public class Demo extends ActionSupport {
	private String username;
	private String password;

	public String getUsername() {
		return username;
	}

	public void setUsername(String username) {
		this.username = username;
	}

	public String getPassword() {
		return password;
	}

	public void setPassword(String password) {
		this.password = password;
	}

	public String execute() throws Exception {
		if (getUsername().equals("Beta")) {
			ActionContext.getContext().getSession().put("user", getUsername());
			System.out.print(getUsername());
			return SUCCESS;
		} else {
			return ERROR;
		}

	}

}

接下来需要配置stuts.xml文件,该文件的最大作用就是配置Action和请求之间的对应关系,并配置逻辑视图名和物理视图资源之间的关系。

<?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.custom.i18n.resources" value="mess" />
	<!-- 指定国际化编码字符集 -->
	<constant name="struts.i18n.encoding" value="UTF-8" />
	<package name="no-default" extends="struts-default">
	<action name="login" class="ntci.cloud.openstack.action.Demo">
<!—定义了三个逻辑视图和物理视图之间的映射 -->
		<result name="input">/login.jsp</result>
		<result name="error">/error.jsp</result>
		<result name="success">/welcome.jsp</result>
	</action>
	</package>

它的整个业务流程如下图所描述的:

1.        在web.xml中定义核心的Filter来拦截用户的请求;

2.        在struts.xml中查找匹配的Action实例,并调用该Action的业务逻辑方法,上图中如果用户请求url为login.action,则使用ntci.cloud.openstack.action.Demo来处理;

3.        当Action处理用户请求完毕后,通常会返回一个处理结果,通常我们称之为逻辑视图名,这个逻辑视图和物理视图进行关系映射;

4.        Action将数据传给视图资源。




Struts 2常量配置

Struts2中有一些常量配置:

struts.i18n.encoding:指定web应用的指定编码集。该常量的默认配置是UTF-8,对于获取中文请求参数,应该将常量设置为GBK或者GBK2312

struts.devMode:该常量设置Struts2应用是否使用开发模式

Struts 2默认会加载类加载路径下的struts.xml、struts-default.xml、struts-plugin.xml三类文件,其中struts.xml是开发者定义的默认配置文件,struts-default.xml是struts 2框架自带的配置文件,而struts-plugin.xml则是Struts     2插件的默认配置文件。除了以上三个文件,我们也可以在struts.properties、web.xml文件中配置struts常量。在struts.xml文件中,在根目录下添加:

<constantname="struts.i18n.encoding" value="UTF-8" />

在web.xml文件filter目录下,添加

<init-param>
         <param-name> struts.i18n.encoding</param-name>
         <param-value> UTF-8</param-value>
</init-param>

为了避免struts.xml过于庞大,我们可以将一个struts.xml配置文件分解为多个配置文件,然后在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元素导入其它配置文件-->
	<include file=”struts-part1.xml”/>
</struts>

Action类

Action类中的属性,不仅可以用于封装请求参数,也可以封装处理结果,Action类并不会对此进行区分。如果请求参数中包含了username属性,则系统会调用Action类中username的setter方法,通过这种方法,username参数就可以传给Action实例。

Struts 2提供了一个Action接口,这个接口提供了Struts2的Action类应该事先的规范,下面是Action接口的代码:

public interface Action{
public static final java.lang.String SUCCESS = "success"; 
public static final java.lang.String NONE = "none"; 
public static final java.lang.String ERROR = "error"; 
public static final java.lang.String INPUT = "input"; 
public static final java.lang.String LOGIN = "login"; 
public abstract java.lang.String execute() throws Exception;
}

Struts 2为Action接口提供了一个实现类ActionSupport,为了方便开发,该类里面提供了很多默认方法,包括数据校验的方法、国际化信息的方法等。






posted @ 2014-07-12 17:33  应律  阅读(220)  评论(0编辑  收藏  举报