struts2基础知识(一)

Struts2

Struts2是在WebWork2基础发展而来的。和struts1一样, Struts2也属于MVC框架。不过有一点大家需要注意的是:尽管Struts2struts1在名字上的差别不是很大,但Struts2struts1在代码编写风格上几乎是不一样的。那么既然有了struts1,为何还要推出struts2。主要是因为struts2有以下优点:

1 > 在软件设计上Struts2没有像struts1那样跟ServletAPIstruts API有着紧密的耦合,Struts2的应用可以不依赖于Servlet APIstruts APIStruts2的这种设计属于无侵入式设计,而Struts1却属于侵入式设计。

public classOrderListAction extends Action {

   public ActionForward execute(ActionMapping mapping,ActionForm form,

                     HttpServletRequest request,HttpServletResponse response)

                     throws Exception {

   }

}

2> Struts2提供了拦截器,利用拦截器可以进行AOP编程,实现如权限拦截等功能。

3> Strut2提供了类型转换器,我们可以把特殊的请求参数转换成需要的类型。在Struts1中,如果我们要实现同样的功能,就必须向Struts1的底层实现BeanUtil注册类型转换器才行。

4> Struts2提供支持多种表现层技术,如:JSPfreeMarkerVelocity

5> Struts2的输入校验可以对指定方法进行校验,解决了Struts1长久之痛。

6> 提供了全局范围、包范围和Action范围的国际化资源文件管理实现

搭建Struts2开发环境

搭建Struts2环境时,我们一般需要做以下几个步骤的工作:

1》找到开发Struts2应用需要使用到的jar文件.

2》编写Struts2的配置文件

3》在web.xml中加入Struts2MVC框架启动配置

搭建Struts2开发环境--开发Struts2应用依赖的jar文件

大家可以到http://struts.apache.org/download.cgi下载struts-2.x.x-all.zip,目前最新版为2.2.1.1。下载完后解压文件,开发struts2应用需要依赖的jar文件在解压目录的lib文件夹下。不同的应用需要的JAR包是不同的。下面给出了开发Struts 2程序最少需要的JAR

struts2-core-2.x.x.jar :Struts 2框架的核心类库

xwork-2.x.x.jar :XWork类库,Struts 2在其上构建

ognl-2.6.x.jar :对象图导航语言(ObjectGraph Navigation Language),struts2框架通过其读写对象的属性

freemarker-2.3.x.jar :Struts 2UI标签的模板使用FreeMarker编写

commons-logging-1.1.x.jar :ASF出品的日志包,Struts2框架使用这个日志包来支持Log4JJDK 1.4+的日志记录。

commons-fileupload-1.2.1.jar 文件上传组件,2.1.6版本后必须加入此文件

搭建Struts2开发环境-- Struts2应用的配置文件

Struts2默认的配置文件为struts.xml ,该文件需要存放在WEB-INF/classes下,该文件的配置模版如下:

<?xml version="1.0"encoding="UTF-8"?>

<!DOCTYPE struts PUBLIC

   "-//Apache Software Foundation//DTD Struts Configuration2.0//EN"

   "http://struts.apache.org/dtds/struts-2.0.dtd">

<struts>

</struts>

搭建Struts2开发环境--Struts2web中的启动配置

struts1.x中, struts框架是通过Servlet启动的。在struts2中,struts框架是通过Filter启动的。他在web.xml中的配置如下:

<filter>

   <filter-name>struts2</filter-name>

   <filter-class>org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter</filter-class>

 <!-- 自从Struts 2.1.3以后,下面的FilterDispatcher已经标注为过时

   <filter-class>org.apache.struts2.dispatcher.FilterDispatcher</filter-class>-->

</filter>

<filter-mapping>

   <filter-name>struts2</filter-name>

   <url-pattern>/*</url-pattern>

</filter-mapping>

StrutsPrepareAndExecuteFilterinit()方法中将会读取类路径下默认的配置文件struts.xml完成初始化操作。

注意:struts2读取到struts.xml的内容后,以javabean形式存放在内存中,以后struts2对用户的每次请求处理将使用内存中的数据,而不是每次都读取struts.xml文件

第一个Struts2应用—HelloWorld

在默认的配置文件struts.xml 中加入如下配置:

<?xml version="1.0"encoding="UTF-8"?>

<!DOCTYPE struts PUBLIC

   "-//Apache Software Foundation//DTD Struts Configuration2.0//EN"

   "http://struts.apache.org/dtds/struts-2.0.dtd">

<struts>

  <package name="csdn" namespace="/test"extends="struts-default">

       <action name="helloworld"class="cncsdn.action.HelloWorldAction" method="execute">

         <resultname="success">/WEB-INF/page/hello.jsp</result>

       </action>

   </package>

</struts>

Struts.xml配置中的包介绍

<package name="csdn"namespace="/test" extends="struts-default">

         <actionname="helloworld" class="cn.csdn.action.HelloWorldAction"method="execute" >

                   <resultname="success">/WEB-INF/page/hello.jsp</result>

         </action>

 </package>

struts2框架中使用包来管理Action,包的作用和java中的类包是非常类似的,它主要用于管理一组业务功能相关的action。在实际应用中,我们应该把一组业务功能相关的Action放在同一个包下。

配置包时必须指定name属性,该name属性值可以任意取名,但必须唯一,他不对应java的类包,如果其他包要继承该包,必须通过该属性进行引用。包的namespace属性用于定义该包的命名空间,命名空间作为访问该包下的Action的路径的一部分,如访问上面例子的Action,访问路径为:/test/helloworld.action namespace属性可以不配置,对本例而言,如果不指定该属性,默认的命名空间为“”(空字符串)。

通常每个包都应该继承struts-default包,因为Struts2很多核心的功能都是拦截器来实现。如:从请求中把请求参数封装到action、文件上传和数据验证等等都是通过拦截器实现的。struts-default定义了这些拦截器和Result类型。可以这么说:当包继承了struts-default才能使用struts2提供的核心功能。 struts-default包是在struts2-core-2.x.x.jar文件中的struts-default.xml中定义。 struts-default.xml也是Struts2默认配置文件。 Struts2每次都会自动加载 struts-default.xml文件。

包还可以通过abstract=“true”定义为抽象包,抽象包中不能包含action

第一个Struts2应用—HellWorld

例子中使用到的cn.csdn.action.HelloWorldAction类如下:

package cn.csdn.action;

public class HelloWorldAction{

         privateString message;

        

         publicString getMessage() {

                   returnmessage;

         }

         publicvoid setMessage(String message) {

                   this.message= message;

         }

         publicString execute() {

                   this.message= "我的第一个struts2应用";

                   return"success";

         }

}

例子中使用到的/WEB-INF/page/hello.jsp如下:

<%@ page language="java"pageEncoding="UTF-8"%>

<!DOCTYPE HTML PUBLIC "-//W3C//DTDHTML 4.01 Transitional//EN">

<html>

 <head>

   <title>第一个struts2应用</title>

 </head>

 <body>

   ${message} <br>

 </body>

</html>

可以使用EL表达式访问Action中的属性。

l  访问HelloWorld应用在struts1中,通过<actionpath=“/test/helloworld”>节点的path属性指定访问该actionURL路径。在struts2中,情况就不是这样了,访问struts2actionURL路径由两部份组成:包的命名空间+action的名称,例如访问本例子HelloWorldActionURL路径为:/test/helloworld(注意:完整路径为:http://localhost:端口/内容路径/test/helloworld)。另外我们也可以加上.action后缀访问此Action

 <package name="csdn"namespace="/test" extends="struts-default">

       <action name="helloworld"class="cn.csdn.action.HelloWorldAction" method="execute">

         <resultname="success">/WEB-INF/page/hello.jsp</result>

       </action>

 </package>

 

 

访问HelloWorld应用

struts1中,通过<actionpath=“/test/helloworld”>节点的path属性指定访问该actionURL路径。在struts2中,情况就不是这样了,访问struts2actionURL路径由两部份组成:包的命名空间+action的名称,例如访问本例子HelloWorldActionURL路径为:/test/helloworld (注意:完整路径为:http://localhost:端口/内容路径/test/helloworld)。另外我们也可以加上.action后缀访问此Action

 <package name="csdn"namespace="/test" extends="struts-default">

       <action name="helloworld"class="cn.csdn.action.HelloWorldAction" method="execute" >

         <resultname="success">/WEB-INF/page/hello.jsp</result>

       </action>

 </package>

Action名称的搜索顺序

1.获得请求路径的URI,例如url是:http://server/struts2/path1/path2/path3/test.action

2.首先寻找namespace/path1/path2/path3package,如果存在这个package,则在这个package中寻找名字为testaction,如果不存在这个package则转步骤3

3.寻找namespace/path1/path2package,如果存在这个package,则在这个package中寻找名字为testaction,如果不存在这个package,则转步骤4

4.寻找namespace/path1package,如果存在这个package,则在这个package中寻找名字为testaction,如果仍然不存在这个package,就去默认的namaspacepackage下面去找名字为testaction(默认的命名空间为空字符串""),如果还是找不到,页面提示找不到action

Action配置中的各项默认值

<package name="csdn"namespace="/test" extends="struts-default">

       <action name="helloworld"class="cn.csdn.action.HelloWorldAction" method="execute">

         <resultname="success">/WEB-INF/page/hello.jsp</result>

       </action>

 </package>

1>如果没有为action指定class,默认是ActionSupport

2>如果没有为action指定method,默认执行action中的execute() 方法。

3>如果没有指定resultname属性,默认值为success

Actionresult的各种转发类型

<action name="helloworld"class="cn.csdn.action.HelloWorldAction">

         <resultname="success">/WEB-INF/page/hello.jsp</result>

</action>

result配置类似于struts1中的forward,但struts2中提供了多种结果类型,常用的类型有: dispatcher(默认值) redirect redirectAction plainText

下面是redirectAction 结果类型的例子,如果重定向的action中同一个包下:

<resulttype="redirectAction">helloworld</result>

如果重定向的action在别的命名空间下:

<resulttype="redirectAction">

         <paramname="actionName">helloworld</param>

         <paramname="namespace">/test</param>

</result>

plaintext:显示原始文件内容,例如:当我们需要原样显示jsp文件源代码的时候,我们可以使用此类型。

<result name="source"type="plainText ">

         <paramname="location">/xxx.jsp</param>

         <paramname="charSet">UTF-8</param><!-- 指定读取文件的编码 -->

</result>

result中还可以使用${属性名}表达式访问action中的属性,表达式里的属性名对应action中的属性。如下:

<resulttype="redirect">view.jsp?id=${id}</result>

 

 

你可能感兴趣的:(struts2基础知识(一))