博客
关于我
struts2的详细执行流程
阅读量:801 次
发布时间:2019-03-25

本文共 1615 字,大约阅读时间需要 5 分钟。

Struts2运行流程详解

在上一篇中,我们已经对Struts2的基本原理进行了简要介绍。本文将详细讲解Struts2的运行流程,并通过一个简单的案例来说明。

案例基础内容

在使用Struts2进行开发之前,需要先进行以下配置:

  • web.xml文件中添加Struts2的过滤器配置
  • 编写Action类(本例使用HelloWorldAction作为示例)
  • struts.xml中配置相应的Action
  • 编写用户界面
  • 接下来,我们将从Struts2的内部运行流程入手,详细剖析其工作原理。

    Struts2的内部运行流程

    当用户提交请求时,请求的URL为:/helloworld/helloworldAction.action。请求会被Tomcat服务器接收到,随后服务器会根据请求的URL路径选择对应的Web应用进行处理。本例中,请求的路径为/helloworld,因此由helloworld这个Web工程来处理。

    步骤说明如下:

  • 请求处理初始化

    Web服务器读取helloworld工程的web.xml文件。在web.xml中配置了扩展名为.action的请求处理规则,其中指定了struts2过滤器来处理此类请求。根据过滤器配置,找到了FilterDispatcher这个类。

  • FilterDispatcher的初始化

    Web容器初始化好了FilterDispatcher类的实例,并通过调用doFilter()方法接收到请求。这是整个Struts2应用中的调度中心,相当于前进到Struts2架构图的第一步。

  • 请求转发到ActionMapper

    FilterDispatcher告诉ActionMapper处理当前的请求。ActionMapper的主要职责是判断请求是否需要Struts2进行处理。这里不会涉及页面控制器,而是专注于动态路由管理。

  • 创建ActionProxy对象

    ActionProxy的职责是代理Action的运行过程。它接收来自FilterDispatcher的请求URL,并向ConfigurationManager询问需要运行哪一个Action。需要注意的是,服务器启动时会将struts.xml文件中的配置一次性读入内存,并缓存起来,以便快速匹配URL和对应的Action。

  • 创建ActionInvocation对象并执行

    ActionProxy知道了需要运行的Action及其相关拦截器,还有所有可能使用的结果信息。它会创建一个ActionInvocation对象来描述Action运行的整个过程。这里的关键在于,拦截器和结果自由地结合在一起,保证整个流程的正确性。

  • 拦截器的执行顺序

    ActionInvocation对象执行过程分为两部分:拦截器(Interceptor)的执行和Action的实际执行。拦截器的应用顺序是前后一致的,确保结果后置拦截器的顺序不会被破坏。

  • Action的执行与结果处理

    在拦截器应用完毕后,调用Action的execute()方法。Action在执行过程中,会直接使用其属性值,不需要从用户的请求域中获取参数。这部分的工作由拦截器完成,其职责是将用户请求中的参数转化为Action属性值。

  • 结果的处理与页面展示

    Action执行完成后,根据返回的result值,在struts.xml中找到对应的页面。页面通常是一个模板页面,采用Struts2自带的标签库来展示需要的数据,生成最终响应内容。

  • 拦截器的后置处理

    最后,拦截器的后置方法按照引用顺序倒序执行。这一环节完成后,整个ActionInvocation流程结束,然后将生成的响应通过定义的过滤器链输出,最终向用户展示结果。

  • 通过以上步骤,我们就清晰地了解了Struts2从接收请求到处理并最终生成响应的完整流程。这个流程不仅仅是关于Action的执行,还涉及到前后拦截器的处理、结果的自由性配置等多个方面。

    转载地址:http://wyuyk.baihongyu.com/

    你可能感兴趣的文章
    Mysql 学习总结(87)—— Mysql 执行计划(Explain)再总结
    查看>>
    Mysql 学习总结(88)—— Mysql 官方为什么不推荐用雪花 id 和 uuid 做 MySQL 主键
    查看>>
    Mysql 学习总结(89)—— Mysql 库表容量统计
    查看>>
    mysql 实现主从复制/主从同步
    查看>>
    mysql 审核_审核MySQL数据库上的登录
    查看>>
    mysql 导入 sql 文件时 ERROR 1046 (3D000) no database selected 错误的解决
    查看>>
    mysql 导入导出大文件
    查看>>
    MySQL 导出数据
    查看>>
    mysql 将null转代为0
    查看>>
    mysql 常用
    查看>>
    MySQL 常用列类型
    查看>>
    mysql 常用命令
    查看>>
    Mysql 常见ALTER TABLE操作
    查看>>
    MySQL 常见的 9 种优化方法
    查看>>
    MySQL 常见的开放性问题
    查看>>
    Mysql 常见错误
    查看>>
    mysql 常见问题
    查看>>
    MYSQL 幻读(Phantom Problem)不可重复读
    查看>>
    mysql 往字段后面加字符串
    查看>>
    mysql 快照读 幻读_innodb当前读 与 快照读 and rr级别是否真正避免了幻读
    查看>>