一:Struts2的起源与背景
在了解Struts2之前我们先来聊聊Struts1,我们都知道在很长的一段时间内,所有的MVC框架中,Struts1他是处于一个超级大咖的地位,无论是从市场角度和使用的用户的数量这个角度而言,Struts1它占用绝对地位,对于其他的MVC框架都不能和他媲美,但是Struts1作为一款优秀的MVC框架他可以很好的实现将控制与业务逻辑相分离,但他自身也存在一定的缺陷。
1.表现层支持单一:
Struts1框架只支持JSP作为其表现层使用,而很多的Java应用,在表现层技术选择时并不一定值使用JSP一种技术,可能会用到FreeMarker,PHP之类的技术等。
2.对Servlet API的依赖:
Struts1框架是基于Model II 模式开发而成的,因此他在开发中会运用到大量的Servlet API,而且我们都知道Servlet API 是要依赖于WEB容器进行初始化的,从而他进一步对WEB容器进行依赖。
3.不利于代码重用:
在Struts1开发的代码中除了自己自定义的类外,还必须使用Struts1中的某些类,这样会带来很多的弊端,与Struts1的类耦合在一起的代码很难再其他系统中进行二次重用。
所以根据以上Struts框架在设计上的缺点,Struts2以WebWork的设计思想为核心,WebWork虽然没有Struts1名气大但是在设计上他避免了S投入他说的弊端,它更强调系统之间的松耦合,使用拦截 器来实现控制,由于不在依赖Web容器,从而解决了框架对Servlet API紧密耦合。所以Strut2是吸收了Struts1的部分优点,建立了一个兼容Struts1和WebWork的MVC框架。
二:Struts2与其优势
Struts 2是一个MVC框架,以WebWork框架的设计思想为核心,吸收了Struts 1的部分优点
Struts 2拥有更加广阔的前景,自身功能强大,还对其他框架下开发的程序提供很好的兼容性
Struts官网
下载下来后的包:
apps目录:Struts2示例应用程序
docs目录:Struts2指南、向导、API文档
lib目录:Struts 2的发行包及其依赖包
src目录:Struts 2项目源代码
三:Struts2的初体验
1.在项目中引入Struts2
必须引入的包
struts2-core.jar——Struts2的核心包
xwork-core.jar——Command模式框架,WebWork和Struts2都基于xwork
commons-logging.jar——Java日志工具类包
freemarker.jar——模板引擎,一个基于模板生成文本输出的通用工具
ognl.jar——Object-Graph Navigation Language,表达式语言,用来获取和设置Java对象属性
可选包
antlr.jar——语法分析器
aopalliance.jar——AOP联盟标准接口
classworlds.jar——class对象管理
commons-beanutils.jar——Bean处理工具类包
commons-chain.jar——流程链处理模型,Struts2处理HTTP请求处理的基础机制
commons-collections.jar——Commons项目组中的一个各种集合类和集合工具类的封装
commons-digester.jar——解析xml转换成Java对象
commons-fileupload.jar——文件上传
commons-io.jar——IO工具类封装
commons-lang.jar——Commons项目中用来处理Java基本对象方法的工具类包
commons-logging-api.jar——Java常用日志工具调用,如通过API调用Log4J
commons-validator.jar——Java对象验证框架
json-lib.jar——用来映射JSON(JavaScript Object Notiation是一种文本格式)到Java Bean的Java类库
oro.jar——文本处理工具
sslext.jar——Struts框架的一个扩展可以让开发者配置Web应用程序在http与https协议之间进行自动转换(需配置)
插件包
struts2-embeddedjsp-plugin.jar——嵌入式JSP插件,可以让你从类路径或者Jar包里面调用JSP页面(官网翻译大概是这个意思)
struts2-convention-plugin.jar——用来实现Struts2零配置的插件包,可以结合这东西实现项目REST风格应用。
struts2-json-plugin.jar——Apache提供的JSON插件包
四:第一个Struts2程序
已我们最为熟悉的登录为例
1.新建一个web项目
2.引入所需jar包
3.在web.xml配置文件中配置我们的过滤器(使用Struts2的核心,不可忘记,在后面会详解)
<?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" xmlns:web="http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd" version="2.5"> <display-name></display-name> <!-- --> <filter> <filter-name>struts2</filter-name> <!-- 使用Struts2的核心类库 --> <filter-class>org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter</filter-class> </filter> <filter-mapping> <filter-name>struts2</filter-name> <!-- 拦截所有的action --> <url-pattern>/*</url-pattern> </filter-mapping> <welcome-file-list> <welcome-file>login.jsp</welcome-file> </welcome-file-list> </web-app>
4.准备我们需要的实体类(用户)
package cn.work.entity; //用户实体类 public class User { 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; } }
在Struts2中,可以直接使用Action类的属性来接收用户的输入,即当表单提交时,Struts2自动对请求参数进行转换,并对具有相同名字的Action属性进行赋值(通过setter方法)
在Struts2中,系统不会识别哪些属性用于接收请求参数,哪些属性用于输出处理结果。只要对属性设置了 setter和getter方法,该属性就可以被自动处理。
此外,Action类中还可以使用复杂的属性,如用户自定义的类,数组,集合对象等。
5.在src下创建名称为struts.xml的配置文件
<?xml version="1.0" encoding="UTF-8" ?> <!DOCTYPE struts PUBLIC "-//Apache Software Foundation//DTD Struts Configuration 2.3//EN" "http://struts.apache.org/dtds/struts-2.3.dtd"> <struts> <constant name="struts.ui.theme" value="simple" /> <constant name="struts.devMode" value="true" /> <!-- package元素用于定义Struts2处理请求的逻辑单元 --> <package name="default" namespace="/" extends="struts-default"> <action name="login" class="cn.work.action.LoginAction2"> <result name="success"> success.jsp </result> <result name="login"> login.jsp </result> <result name="input">login.jsp</result> </action> </package> </struts>
1.package元素用于定义Struts2处理请求的逻辑单元,name属性为必需的并且唯一,用来指定包的名称(被其他包引用),extends属性类似java的extends关键字,用于指定要扩展的包。
2.action元素用于配置Struts2框架的“工作单元”Action类。action元素将一个请求的URI(action的名字)对应到一个Action类。name属性是必需的,用来表示action的名字,class属性可选,用于设定Action类的全限定名。
3.result元素用来设定Action类处理结束后,系统下一步将要做什么。name属性表示result的逻辑视图名称,必需与Action类返回的字符串进行匹配,而result元素的值表示与逻辑视图名称对应的物理资源之间的映射,用来指定这个结果对应的实际资源的位置。
注:在struts.xml文件中,每一个result属性的name名称都要与Action中返回的逻辑名称保持一致,否则,程序在运行时将无法正确运行。
6.创建一个继承了Action接口的LoginAction类
package cn.work.action; import java.util.ArrayList; import java.util.List; import java.util.Map; import cn.work.entity.User; import com.opensymphony.xwork2.Action; import com.opensymphony.xwork2.ActionContext; import com.opensymphony.xwork2.ActionSupport; public class LoginAction extends ActionSupport implements Action { /** * */ private static final long serialVersionUID = 1L; private User user; private List<String> list; public List<String> getList() { return list; } public void setList(List<String> list) { this.list = list; } public String execute() throws Exception { if (user.getUsername().equals("张总")&&user.getPassword().equals("521")) { /** * 1.Struts2访问ServletAPI对象 * 方式一: **/ //获取session Map<String, Object> session = ActionContext.getContext().getSession(); //将值存入session session.put("username",user.getUsername()); return SUCCESS; }else { return LOGIN; } } public User getUser() { return user; } public void setUser(User user) { this.user = user; } //数据校验 public void validate(){ if (this.user.getUsername().length()==0) { addFieldError("name2", "用户名不能为空"); } if (this.user.getPassword().length()==0) { addFieldError("pwd2", "密码不能为空"); } } }
7.用于登录的login.jsp页面
<%@ page language="java" import="java.util.*" pageEncoding="utf-8"%> <% String path = request.getContextPath(); String basePath = request.getScheme() + "://" + request.getServerName() + ":" + request.getServerPort() + path + "/"; %> <%@taglib uri="/struts-tags" prefix="s"%> <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> <html> <head> <base href="<%=basePath%>"> <title>登录页面</title> </head> <body> <div> <h1>用户登录</h1> <!-- 用于输出验证信息 --> <s:fielderror /> <!-- 表单的提交 --> <s:form action="login.action" method="post"> 用户名:<s:textfield name="user.username" type="text" /> 密码:<s:textfield name="user.password"type="password" /> <s:submit type="submit" value="登录"/> </s:form> </div> </body> </html>
8.成功的success.jsp页面
<%@ page language="java" import="java.util.*" pageEncoding="utf-8"%> <% String path = request.getContextPath(); String basePath = request.getScheme() + "://" + request.getServerName() + ":" + request.getServerPort() + path + "/"; %> <%@taglib uri="/struts-tags" prefix="s"%> <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> <html> <head> <base href="<%=basePath%>"> <title>成功页面</title> </head> <body> <h1>登录成功</h1> <div>欢迎您,${session.username}</div> <s:property value="user.username" /> <s:property value="user.password" /> </body> </html>
先这样吧!这就是Struts2的入门,以后再继续探索Struts2的奥秘。。。