与struts1框架的使用同样,struts2的环境搭建及使用一样分为如下几个步骤:html
1. 引入jar包(这里以struts2.2.3为例),所需jar包有如下几个:java
a) struts2-core-2.2.3.jarweb
b) xwork-core-2.2.3.jarapache
c) commons-io-2.0.1.jar服务器
d) commons-lang-2.5.jarapp
e) commons-fileupload-1.2.2.jar框架
f) freemarker-2.3.16.jarjsp
g) ognl-3.0.1.jaride
h) javassist-3.12.0.GA.jar(hibernate一样须要)ui
2. 配置web.xml文件。全部的web项目都是以web.xml文件为起点的,全部的起始配置都在这个文件中进行,而所谓的起始配置则是指在服务器启动时所读取的配置。好比咱们常常所用到的框架的配置,servlet的配置,filter的配置等信息。Struts2的web.xml文件与struts1的有所不一样,使用struts1框架时用servlet标签进行配置来关联项目和框架,而使用struts2用的是filter标签来关联项目和框架。总的来讲原理相同,都是经过映射来制定哪些类型的页面须要交给框架去处理(在下文实例中会具体给出配置信息)。
3. 须要被框架核心类读取的xml文件的配置。在struts1中这个xmL文件名称为struts-config,而struts2中该文件的名称为struts.xml。名字的差别可有可无,重要的是该文件中的配置信息有所不一样,主要在于Struts-config中咱们定义了不少的ActionForm以及Action类,这些Action必须继承ActionServlet抽象类,可是在struts2中已经没有了ActionForm这个概念,原先ActionForm所承担的职责已经被转移到Action中,而且struts2中的Action支持彻底的POJO对象,固然也能够继承相应的ActionSupport类。
完成了上面的配置后接下来就是编写咱们的Action类了,下面经过一个登录实例来介绍struts2的使用。
Web.xml文件配置信息以下:
<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://java.sun.com/xml/ns/javaee" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd" id="WebApp_ID" version="2.5">
<display-name>SSH5</display-name>
<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>
</web-app>
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>
<constant name="struts.action.extension" value=","></constant>
<package name="testLogin" namespace="/" extends="struts-default">
<action name="login" class="com.action.LoginAction">
<result name="success">/user.jsp</result>
<result name="error" type="redirect">/error.jsp</result>
<result name="checkError">/checkSession.jsp</result>
<interceptor-ref name="defaultStack"></interceptor-ref>
</action>
</package>
</struts>
LoginAction类:
package com.action;
import com.entity.User;
import com.opensymphony.xwork2.ActionSupport;
public class LoginAction extends ActionSupport {
private User user;
public User getUser() {
return user;
}
public void setUser(User user) {
this.user = user;
}
@Override
public String execute() throws Exception {
if("admin".equals(user.getUsername()) && "admin".equals(user.getPassword())){
System.out.println("登陆成功");
return "success";
}else{
System.out.println("登陆失败");
return "error";
}
}
}
最后是jsp页面代码:
<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>Insert title here</title>
</head>
<body>
<form action="login">
登陆页面<br>
用户名:<input name="user.username" type="text" ><br>
密码:<input name="user.password" tyep="password"><br>
<input type="submit" value="登陆">
</form>
</body>
</html>
上述登陆实例的执行过程为当启动TomCat的时候TomCat首先加载web.xml,根据web.xml中的配置信息由
org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter类读取struts.xml中的信息,而后根据web.xml文件中规定的拦截文件路径肯定哪些页面将会交由struts框架进行处理,通常配置成/*,表示将对全部的页面进行出拦截处理,而后根据jsp页面中的提交路径以及struts.xml文件中的配置信息肯定该页面将提交给哪一个Action。当所提交的请求被Action处理后,将根据执行结果返回相应的字符串,根据返回值将决定具体的跳转页面。