现在的位置: 首页 > 综合 > 正文

Struts 2读书笔记—–Struts 2知识总结

2012年08月04日 ⁄ 综合 ⁄ 共 7938字 ⁄ 字号 评论关闭

          历时三个星期的时间终于把Struts 2 给看完了。中间断断续续的学习,在这个过程中学到了很多东西,也真正的明白了时间是挤出来的。大三了课程越来越来多了,有自己学校的课程要学习,又是各种各样的实验,时间的真的是太紧了。这个时间,利用一切的空余时间来学习编程。这个过程的苦和乐真的只有经历了才明白...

         不多说了,下面是对这三个星期学习Struts 2的知识总结:

 

        一、Struts 2应用的开发步骤

         1、首先要先下载Struts 2jar包,将必须的类库放入到Web应用下的WEB-INF/lib路径下。

         2、配置web应用的web.xml配置文件,配置Struts 2的核心Filter

         3、定义处理用户请求的Action

         4、配置Action

         5、配置处理结果和物理试图资源之间的对应关系

 

        二、Struts 2的配置

        1Action访问Servlet API

         Struts 2提供了一个ActionContextStruts 2action可以通过该类来访问Servlet API

         该类包含了以下几个常用的方法:getApplicationgetContextgetParametersgetSessionsetApplicationsetSession通过上面几个方法我们获得servlet的对象,并可以对其进行相应的操作。

         当然Action还可以直接访问Servlet API。不过需要实现相应的接口:

         ServletContextAwareServletRequestAwareServletResponseAware,实现上面的接口仅仅只需要实现相应的setXxxxxXxxxx方法就可以了。

         2、配置Action

         package

         Struts 2是使用包来组织管理Action和拦截器等的,每个包可以配置多个Action、多个拦截器、多个拦截器引用,我们可以将包看做是他们的一个集合。

         配置包<package.../>元素的时候必须指定name属性。该属性是引用该包的唯一标识。

         <package..../>元素有如下几个属性:nameextendsnamespaceabstract

         配置如下:

	<package name="mypackage" extends="struts-default">
	.....................
	</package>

 

        Action

        定义Action的时候,像配置<package.../>元素一样,也要指定一个name属性,该name属性的名字就是该Action的名字。但是Action还要指定一个class属性。该属性指该Action的实现类。

        注:class属性并不是必须的,如果我们不为Action指定class属性,系统会默认使用系统的ActionSupport类。

        一个简单的Action的配置如下:

	<package name="lee">
		<action name="login" class="com.app.action.LoginAction"></action>	
	</package>

        Action只是一个逻辑控制器。它并不会直接作用于浏览器,也就是说他不会直接对浏览者生成任何响应。所以,Action处理完用户请求后,Action需要将指定的视图资源呈现个用户。故,在配置Action的时候应该配置逻辑视图和物理视图资源之间的对应关系。

配置action的时候,一般还要指定method属性。该属性指定实现用户请求的方法。如果不指定method属性,系统默认使用execut方法来处理用户的请求。

        对于method属性,我们还可以使用通配符。

        如下:

<action name="*Action" class="com.app.action.LoginAction" method="{1}" />

         result

         每个<result.../>元素定义逻辑试图和物理试图之间的一次映射。

         <result.../>元素应该定义一个name属性。该属性指定所配置的逻辑视图名,也就是相应的action返回的逻辑视图名。当然也可以不需要指定name属性,这时系统会默认使用success

         <result.../>元素还存在一个type属性,该属性指定结果类型。Struts 2支持的结果类型有:ChaindispatcherfreemarkerhttpheaderredirectstreamvelocityxsltplainText。当不指定type属性时,系统默认dispatcher

         <result.../>元素的配置片段如下:

	<action name="login">
			<!-- 配置默认结果,省略type属性,默认dispatcher -->
			<result>/welcome.jsp</result>
	</action>

         上面的配置比较简单,但是这是Struts 2最基本配置。

 

         三、Struts 2的异常处理

         我们在实现execute方法的时候,该方法是将异常直接抛出,交给Struts 2框架来处理。                 

         这就意味着,我们在处理用户请求的时候,可以不需要对异常进行处理,直接抛出交给Strust 2处理,Struts 2接收到Action抛出的异常之后,将会根据struts.xml文件配置的异常映射关系,转入到指定的视图资源。

         Strut 2的异常处理机制是通过在struts.xml文件中配置<exception-mapping.../>元素完成的。配置该元素时,需要指定如下两个属性:exceptionresult

         如下:

	<!-- 定义全局异常映射 -->
		<global-exception-mappings>
			<!-- 当Action中遇到SQLException异常时,系统将会转入到name问sql的结果中 -->
			<exception-mapping result="sql" exception="java.sql.SQLException"></exception-mapping>
			<!-- 当Action中遇到Exception异常时,系统将会转入到name为root的结果中 -->
			<exception-mapping result="root" exception="java.lang.Exception"></exception-mapping>
		</global-exception-mappings>

        对于异常的输出,我们采用如下方式:

	<s:property value="exception"/>

 

         四、使用Struts 2国际化

        Strut 2的国际化是建立在java国际化的基础上的。对于Struts 2的国际化我们一般采用加载全局的国际化资源文件,加载全局的国际化资源文件的方式是通过配置常量来实现的。在文件中配置我们只需要配置struts.custom.i18n.resoutces常量即可。

        配置struts.custom.i18n.resoutces常量时,该常量的值为全局国际化资源文件的baseName。一旦指定了全局的国际化资源文件,既可以实现程序的国际化。

        struts.xml文件中我们需要配置如下代码:

	<!--指定Struts 2国际化资源文件的baseName为messageResource -->
	<constant name="struts.custom.i18n.resoutces" value="messageResource" />

        对于国际化资源文件,我们一般采用键值对的properties文件。为了在页面中输出国际化资源,我们可以使用Struts 2<s:text.../>标签,该标签的name属性,指定了国际化资源文件中的key

 

         五、Strut 2的类型转换

        Struts 2的类型转换可以基于ONGL表达式。只要我们把Http参数的命名为合法的ONGL表达式,就可以充分的利用Struts 2的类型转换机制。

        对于Struts 2内建的类型转换,我们无需理会,不需要做任何特殊的处理。

        自定义类型转换

        对于用户自定义类型转换器,用户必须要实现TypeConverter接口。实现自定义类型转换器需要重写该方法的convertValue方法。

        该方法是双向的。可以将字符串转换成复合类型,也可以将复合类型转换为字符串。该方法主要是通过toType参数来判断转换的方向。

        其实基于Struts 2的自定义类型转换器,我们可以有更简单的方法实现。Struts 2提供了一个StrutsTypeString抽象类。该抽象类提供了两个方法:convertFromStringconvertToString。通过实现这个两个方法就可以实现自定义类型转换了。

        如下:

	public class UserConverter extends StrutsTypeConverter{
	       //实现将字符串类型转换为复合类型的方法
	        public object converterFromString(Map context,String[] values,Class toClass){
	             ..............................
	       }
	
	      //实现将复合类型转换为字符串类型的方法
	        public String converterToString(Map context,Object o){
	             ....................
	       }
	}

        完成了自定义类型转换器后,还要将类型转换器注册到Web应用中去:

        局部类型转换器:

        <proName>=<ConverterClass>

        <proName>:需要进行类型转换的属性

        <ConverterClass>:类型转换器的实现类

        如下:

	user = com.app.converter.UserConverter

        全局类型转换器:

        <propType>=<ConvertClass>

        <propType>:需要进行类型转换的类型

        <ConvertClass>需要进行类型转换的实现类

        如下:

	com.app.domain.User = com.app.converter.UserConverter

 

         六、使用Struts 2的输入校验

        Struts 2提供了基于验证框架的输入校验,在这种校验方式下,所有的输入校验只需要编写简单的配置文件,Struts 2的验证框架将会负责进行服务器校验和客服端校验。     

        1、编写校验规则文件

        校验规则文件的根元素是<validator.../>元素,<validator.../>元素可以包含多个<field../><validator.../>,他们都用于配置校验规则。

        配置片段:

	<validators>
		<!-- 校验Action的name属性 -->
		<field name="name">
			<!-- 指定name属性必须满足必填规则 -->
			<field-validator type="requiredstring">
				<param name="trim">true</param>
				<message>必须填入名字</message>
			</field-validator>
		</field>
	</validators>

        对于校验规则文件的命名采用这个格式:<Action 名字>-validation.xml

        对于使用客服端校验。我们只需要为<s:form.../>元素增加validate="true",就可以实现客服端校验了。但是如果我们希望Struts 2的客服端校验能够起作用,那么我们在进入相应的页面之前必先经过Struts 2 的核心Filter

        2、两种校验配置风格

        Struts 2提供了两种方式来配置校验规则:字段校验器风格,非字段校验器风格

        字段校验器风格:

<field name="被校验的字段">
	<field-validator type="校验器名">
	<!-- 此处需要为不同校验器指定数量不等的校验参数-->
	<param name="参数名">参数值</param>
	......
	<!-- 校验失败后的提示信息,其中key指定国际化信息的key-->
	<message key="I18Nkey">校验失败后的提示信息</message>
	</field-validator>
	<!-- 如果该字段需要满足多个规则,下面可以配置多个校验器-->
</field>

        非字段校验器风格:

<validator type="校验器名">
	<param name="fieldname">需要被校验的字段</param>
	<!-- 此处需要为不同校验器指定数量不等的校验参数-->
	<param name="参数名">参数值</param>
	.....
	<!-- 校验失败后的提示信息,其中key指定国际化信息的key-->
	<message key="I18Nkey">校验失败后的提示信息</message>
 </validator>

        3、短路校验器

        如果我们希望在进行输入校验的时候,对于提示信息我们并不希望一次性全部输出来,而是根据相应的错误,输出相应的提示信息。这个时候,我们就可以使用短路校验器。

        采用短路校验器,只需要在<validator.../>元素或<field-validator.../>元素中增加short-circuit="true"即可。

        4、手动完成输入校验

        如果需要手动完成输入校验,一般是重写ActionSupport类的validate方法,在重写这个方法的时候,一旦担心校验失败后,就需要把校验失败提示信息通过addFieldError方法添加到系统的FieldError中。除此之外,不需要做任何额外的处理。

        或者重写validateXxx方法。其中的Xxx代表了Action对应的处理逻辑方法。其他的和validate方法差不多。不过需要在struts.xml文件中指定该方法。让该Action的该方法来处理这个请求。

        Struts 2的输入校验需要经过以下几个步骤:

          1、类型转换器负责对字符串的请求参数执行类型转换,并将这些值设置为Action的     属性值。

          2、在执行类型转换过程中可能出现异常,如果出现异常,将异常信息保存到ActionContext中。conversionError拦截器负责将其封装到FieldError里,然后执行第三步;如果转换过程中没有异常信息,则直接进入第三步。

          3、使用Struts 2应用配置的校验器进行输入校验

           4、通过反射调用validateXxx()方法,其中Xxx是即将处理用户请求的处理逻辑所对应的方法。

           5、调用Action类里的validate方法。

          6、如果经过上面5步都没有出现FieldError,将调用Action里处理用户请求的处理方法;如果出现了FieldError,系统将会转入input逻辑视图所指定的视图资源。

        流程如下:

           

           七、使用Struts 2控制文件上传

           为了能上传文件,我们必须将表单的method设置为POST,将enctype设置为multipart-form-data。只有这样,浏览器才会把用户选择文件的二进制数据发送给服务器。

           1、上传逻辑控制的Action

           Action包含两个属性:uploadFileNameuploadContentType,这两个属性分别用来封装上传文件的文件名、上传文件的文件类型。

           控制文件上传的Action一般需要使用三个属性来封装文件域的信息:

           类型为Filexxx属性封装了该文件域对应的文件内容

           类型为StringxxxFileName属性封装了该文件域对应的文件的文件名

           类型为StringxxxContentType属性封装了该文件域对应的文件的文件类型。

           配置文件上传的Action和其他配置Action的文件差不多。

           2、手动实现文件过滤

           我们可以通过文件过滤来实现对上传者上传的文件进行限制。

           如果需要手动实现文件过滤,需要进行如下步骤:

              1)、在Action中定义一个专用于进行文件过滤的方法。

              2)为了让应用程序可以动态配置允许上传的文件列表,为该Action增加一个allowTypes属性,该属性的值列出了所有允许上传的文件类型。

              3)利用Struts 2的输入校验来判断用户输入的文件是否符合要求。

              4)书写struts.xml配置文件

           3、拦截器实现文件过滤

           其实使用拦截器来实现文件过滤更加方便。毕竟手动实现,书写的代码量大了。

           配置fileUpload拦截器时,需要指定两个参数:allowedTypesmaximumSize

           配置代码如下:

	<interceptor-ref name="fileUpload">
	<param name="allowedTypes">image/png,image/gif</param>
	<param name="maximumSize">200</param>
	</interceptor-ref>

           

           八、使用Struts 2控制文件下载

           相对于文件上传,文件下载简单些。

           Struts 2的文件下载的Action与普通的Action有点不同,该Action需要提供一个返回

抱歉!评论已关闭.