Struts2入门3 深入学习

Struts2入门3 深入学习 处理结果和异常

前言:

         Struts学习的差不多了,还有最后的一点就收官了就是结果处理和异常处理。前面学习Struts主要围绕就是Action以及struts.xml配置方法,通过简单的编程实现了struts的基本功能。其实这样的入门效果就达到了,因为任何一个框架技术,如果想速成,就拿出一天的时间来学习;但是想要掌握到炉火纯青的地步,那就是在平时的项目中利用它去解决实际的问题,同时不断的深入框架,直到源代码级别。单独学习完这几个框架,后面还有很多的事情,就是讲它们整合,还有Spring的一大块东西,同时在Java中有很多的设计模式,那本厚厚的设计模式,不知能不能够看下去。同时这本SSH的后面的实验要做吗?也是个问题,不纠结了,还是先把Struts2看完最后这一点入门的知识。

1.处理结果

         Action是Struts2的业务控制器,他负责处理用户的请求,并且通过调用业务处理逻辑进行业务处理。当Action处理完毕,处理结果会通过视图展示,而Action本身是不直接提供针对用户请求的响应,但是Action控制器应该能够控制将那个试图资源呈现给读者。Struts2的Action中只会返回一个字符串。

1.1处理结果的流程

         这个流程就不总结了,其实最终显示给用户的视图资源不仅有JSP还有Velocity或者是FreeMarket这里,因为Struts支持多种视图资源,同时在视图层,EL表达式是十分重要的,可以直接获得很多的数据资源,同时还有标签,可以节省很多的代码资源。

1.2result配置信息

Struts2中提供了两种结果配置:

局部结果:将result元素作为action的子元素出现

         <result name=”success” type=”dispatcher”>视图资源</result>

全局结果:将result元素作为<global-results>元素配置

         <package name=”test” extends=”struts-default”>

                   <global-results>

                            <result name=””>视图资源</result>

                   </global-results>

         </package>

         这样的会给他提供一个全局的默认结果success,这个全局结果的作用范围对所有的Action都会有效。但是局部结果优先有全局结果。

1.3result的类型

         Struts2支持多种视图技术,可以和JSP,Velocity, FreeMarket, XSLT等等视图技术整合。Action处理结束之后,返回的普通字符串就是逻辑视图,根据在上struts.xml中的配置,可以使得逻辑视图资源和物理视图资源产生映射关系,默认的result都是dispatcher类型的。Struts2默认提供了result类型:

chain 用于进行Action链式处理

chart         整合JFreeChart技术

dispatcher 整合JSP页面技术

freemarket       整合FreeMarket技术

httpheader       控制特殊行为的http行为

jasper       整合JasperReport技术

jsf     整合JSF技术

redirect    用于重定向到其他的URL

redirectAction 重定向到其他的Action

stream 向浏览器返回InputStream,一般用于文件下载

tiles 用于整合Tiles技术

velocity    整合velocity技术

xslt   整合XML/XSLT技术

plaintext  显示源代码

关于redirect和dispatcher是相对的,dispatcher是将请求结果转发到指定的JSP资源,而redirect的结果类型则意味者将请求重定向到指定的视图资源。

         Dispatcher和Redirect的主要区别是在转发和重定向上:重定向会丢失所有的请求参数,请求属性,同时Action处理的结果也会丢失,当使用redirect的时候,系统实际上会调用HttpServletResponse的sendRedirect()方法来重定向指定的视图资源,这种效果就是重新生成一个请求,之前请求的所有参数、属性、Action对象等等都会丢失,一般重定向使用在发生错误,不知如何处理,到ERROR界面,或者是主页;或者是登陆的时候,登陆成功,重定向到主页。

         redirectAction结果类型和redirect的结果类型是相似的,同样也会生成一个新的请求,当需要在Action处理结束之后直接将请求重定向到另一个Action的时候,配置redirectAction的结果类型实现,同时还可以指定 actionName属性和namespace

         <action name=”login” class=”com.yang.stru2.action.LoginAction”>

                   <result name=”success” type=”redirectAction”>

                            <param name=”actionName”>listuser</param>

                            <param name=”namespace”>/user</param>

                   </result>

         </action>

1.4动态的result

         不怎么喜欢使用,就是表示是匹配,

         <package name="user" extends="struts-default">

        <action name="*user" class="com.yang.stru2.action.UserAction" method="{1}"> 这里的{1}就表示的是不确定的哪一个部分

            <result>/{1}.jsp</result>

        </action>

    </package>

2.异常处理

    一个程序的健壮,关键不是程序不会出错,而是出错了,如果保证程序能够继续运行。因为没有程序不存在错误。在实际的应用中,有些异常是因为违反了业务逻辑而导致的错误,和特定的业务相关,这种错误不能进行声明式处理,只能够使用编程进行处理,还有一些莫名奇怪的错误,但是有经常存在:

    无法处理:系统级别或者是资源级别的,于Web的逻辑无关的,比如网络原因导致的数据库连接失败

    和业务处理无关,但是需要用户重定向到执行额外操作的页面,比如用户未登录,这个时候就会跳转。

    和业务逻辑相关,修改工作的流程解决,比如数据并发的问题和资源锁的问题

    任何成熟的框架都会提供相当完善的异常处理机制,Struts2就是这样,他提供了一种声明式的异常处理机制。当Action处理用户请求的时候,比如出现了异常1,则Struts2会捕获异常之后,按照struts.xml配置的映射,转入到exception1.jsp页面进一步处理。这种方式使得异常处理和代码的耦合度降低,便于维护。

    关于异常的配置信息,在struts.xml中配置<exception-mapping>元素来完成,配置元素的一下属性:

    exception:指定Action出现的异常所映射的异常类型

    result:指定Action抛出异常的时候,系统转入该属性值对应的Action或者是global-results中配置的result

    同时<exception-mapping>还分为局部异常映射和全局异常映射:

    局部异常映射:将<exception-mapping>元素作为<action>的子元素配置

    全局异常映射:将<exception-mapping>元素作为<global-exception-mappings>的子元素配置:

<package name="login" extends="struts-default">

    <action name="login" class="com.yang.stru2.action.LoginAction">

        <exception-mapping result="error" exception="java.lang.RuntimeException"></exception-mapping>

        <result name="error">/user/error.jsp</result>

    </action>

</package>

 

YangTengfei

2013.11.30

你可能感兴趣的:(struts2)