Struts2学习教程之 * 机制与自定义 *

作者:果冻想 时间:2021-10-27 13:02:56 

前言

* 体系是Struts2框架的重要组成部分,不夸张的说,没有 * 体系,也就没有这么好用的Struts2框架了。在Struts2框架中,大量的 * 完成了很多基础的功能,比如,params * 负责解析HTTP请求的参数,并设置Action的属性;servlet-config * 直接将HTTP请求中的HttpServletRequest实例和HttpServletResponse实例传给Action;fileUpload * 则负责解析请求参数中的文件域,并将一个文件域设置成Action的三个属性......这一切的一切都是由内建的 * 来完成的。所以,掌握了Struts2中 * 的使用原理与方式,也就把握住了Struts2框架的“命脉”。

但是学习Struts2到现在,除了在web.xml中配置了一个StrutsPrepareAndExecuteFilter过滤器外,还没有接触其它的什么 * ,那为什么我们的应用能够很好的运行呢?实际上,Struts2已经默认启用了大量通用的 * ,只要配置Action的package继承了struts-default包,这些 * 就会起作用。下面来看看Struts2内建的 * 。

Struts2内建的 *

在Struts2框架中有很多内建的 * ,这些 * 几乎完成了Struts2框架70%的工作,包括解析请求参数,将请求参数赋值给Action属性等,Struts2这种灵巧的设计,很大程度上得益于 * 的设计;当需要扩展Struts2功能时,只需要提供对应 * ,并将它配置在Struts2容器中即可。

这些内建的 * 以name-class对的形式配置在struts-default.xml文件中,其中name是 * 名字,就是以后使用该 * 的唯一标识;class则指定了该 * 的实现类。对于这些内建的 * 的详细介绍,请参见官方文档。

配置 *

在Struts.xml文件中定义 * 只需为 * 类指定一个 * 名,就完成了 * 定义。定义 * 使用<interceptor.../>,例如:


<!-- 通过指定 * 名和 * 实现类来定义 * -->
<interceptor name=" * 名" class=" * 实现类">
 <param name="参数名">参数值</param>
</interceptor>

除此之外,还可以把多个 * 连在一起组成 * 栈,在 * 中使用<interceptor-ref .../>来定义 * 引用。例如:


<interceptor-stack name=" * 栈一">
 <interceptor-ref name=" * 一"/>
 <interceptor-ref name=" * 二"/>
 ...
</interceptor-stack>

从程序结构上来看, * 栈由多个 * 组成;但是从程序功能上来说, * 栈和 * 是一样的,它们包含的方法都会在Action的execute方法执行之前自动执行。所以,我们完全可以把 * 栈当成一个更大的 * 。

由于 * 栈和 * 是一致的,所以 * 栈中又可以包含 * 栈,例如:


<interceptor-stack name=" * 栈二">
 <interceptor-ref name="modelDriven"/>
 <interceptor-ref name=" * 栈一"/>
</interceptor-stack>

使用 *

一旦定义了 * 栈和 * 后,就可以使用这个 * 栈或 * 来拦截Action了, * 的拦截行为将会在Action的execute方法执行之前被执行。

通过使用<interceptor-ref .../>元素可以在Action内使用 * ,在Action中使用 * 的配置语法与配置 * 栈时引用 * 的语法完全一样。例如:


<action name="login" class="com.jellythink.practise.LoginAction">
 <result name="error">/error.jsp</result>
 <result name="success">/welcome.jsp</result>
 <!-- * 栈 -->
 <interceptor-ref name="defaultStack"/>
 <!-- * -->
 <interceptor-ref name="test1"/>
 <!-- 带参数的 * -->
 <interceptor-ref name="test2">
   <param name="key">动态参数</param>
 </interceptor-ref>
</action>

这样配置完成以后,在执行DownloadAction之前,这三个 * 都会起作用。

配置默认 *

当配置一个包时,可以为其指定默认 * 。一旦为某个包指定了默认的 * ,如果该包中的Action没有显式指定 * ,则默认的 * 将会起作用。但是,一旦我们为该包中的Action显式应用了某个 * ,则默认的 * 不会起作用;如果该Action需要使用该默认 * ,则必须手动配置该 * 的引用。

只有当Action中没有显式应用 * 时,该Action所在包的默认 * 才会生效。

配置默认 * 使用<default-interceptor-ref.../>元素,该元素作为<package.../>元素的子元素使用,为该包下的所有Action配置默认的 * 。例如:


<default-interceptor-ref name="默认 * "/>

也可以为默认 * 指定参数,例如:


<default-interceptor-ref name="默认 * ">
 <param name="参数名">参数值</param>
</default-interceptor-ref>

在struts-default.xml文件中,配置了一个名为struts-default的抽象包,在该包中定义了名为defaultStack的默认 * 引用。当我们定义的包继承struts-default包时,也继承了它的默认 * 栈:defaultStack,这也意味着,如果我们不为Action显式地应用 * ,则defaultStack * 栈会自动生效。

自定义 *

1>.添加一个类,让它继承AbstractInterceptor类,或者实现Interceptor接口


public class TimeInterceptor extends AbstractInterceptor {
/**
* * 的核心方法intercept的返回值是一个字符串
*/
@Override
public String intercept(ActionInvocation invocation) throws Exception {
// TODO Auto-generated method stub
return "login";
}
}

2>.在struts.xml的package中添加interceptors子节点,并在它下面添加Interceptor节点


<package name="goods" namespace="/goods" extends="common-pkg">
<interceptors>
<interceptor name="timeInterceptor" class="com.wskj.struts2.interceptor.TimeInterceptor"></interceptor>
</interceptors>
</package>

3>.在想被拦截的action节点下添加子节点interceptor-ref


<action name="list_Category" class="com.wskj.struts2.controller.CategoryAction" method="list">
<interceptor-ref name="timeInterceptor"></interceptor-ref>
<result name="list" type="dispatcher">/pages/Category/list.jsp</result>
</action>

总结

这篇文章对Stuts2中的核心—— * 进行了一个初步的总结,在后面的文章中,我们会实现一个我们自己的 * ,并将这篇文章中总结的知识点进行运用。

好了,以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对脚本之家的支持。

来源:https://www.jellythink.com/archives/303

标签:struts2, ,
0
投稿

猜你喜欢

  • Java接口幂等性设计原理解析

    2022-12-22 12:27:01
  • C#使用ILGenerator动态生成函数的简单代码

    2022-07-10 01:41:06
  • 一文带你认识Java中的Object类和深浅拷贝

    2023-02-05 16:52:08
  • 详解C#中HashTable的用法

    2023-07-17 04:42:07
  • Redis原子计数器incr,防止并发请求操作

    2021-07-03 13:35:15
  • 新浪微博第三方登录界面上下拉伸图片之第三方开源PullToZoomListViewEx(二)

    2021-07-25 04:52:35
  • Java8新特性:函数式编程

    2021-12-01 03:09:02
  • Kotlin协程Channel源码示例浅析

    2023-06-14 22:54:08
  • C#中Params的用法

    2023-06-03 22:23:27
  • 关于Spring Boot项目的 log4j2 核弹漏洞问题(一行代码配置搞定)

    2022-08-26 03:04:20
  • c#多线程的应用全面解析

    2023-03-03 21:15:02
  • Android6.0仿微信权限设置

    2023-03-03 09:40:30
  • 最值得Java开发者收藏的网站

    2022-03-09 15:57:08
  • C#中比较常用的DateTime结构的使用方法

    2023-01-06 21:33:11
  • Spring Cloud中Sentinel的两种限流模式介绍

    2021-11-22 00:38:10
  • Android使用ScrollView实现滚动效果

    2023-05-01 13:25:16
  • C#实现简单计算器功能

    2023-02-13 19:26:44
  • springboot 自定义异常并捕获异常返给前端的实现代码

    2022-07-23 03:09:52
  • 整理总结Java多线程程序编写的要点

    2022-02-19 16:17:23
  • java统计字符串中指定元素出现次数方法

    2022-11-02 16:05:40
  • asp之家 软件编程 m.aspxhome.com