博客
关于我
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/

    你可能感兴趣的文章
    nyoj58 最少步数
    查看>>
    OAuth 及 移动端鉴权调研
    查看>>
    OAuth2 + Gateway统一认证一步步实现(公司项目能直接使用),密码模式&授权码模式
    查看>>
    OAuth2 Provider 项目常见问题解决方案
    查看>>
    OAuth2 vs JWT,到底怎么选?
    查看>>
    Vue.js 学习总结(14)—— Vue3 为什么推荐使用 ref 而不是 reactive
    查看>>
    oauth2-shiro 添加 redis 实现版本
    查看>>
    OAuth2.0_JWT令牌-生成令牌和校验令牌_Spring Security OAuth2.0认证授权---springcloud工作笔记148
    查看>>
    OAuth2.0_JWT令牌介绍_Spring Security OAuth2.0认证授权---springcloud工作笔记147
    查看>>
    OAuth2.0_介绍_Spring Security OAuth2.0认证授权---springcloud工作笔记137
    查看>>
    OAuth2.0_完善环境配置_把资源微服务客户端信息_授权码存入到数据库_Spring Security OAuth2.0认证授权---springcloud工作笔记149
    查看>>
    OAuth2.0_授权服务配置_Spring Security OAuth2.0认证授权---springcloud工作笔记140
    查看>>
    OAuth2.0_授权服务配置_令牌服务和令牌端点配置_Spring Security OAuth2.0认证授权---springcloud工作笔记143
    查看>>
    OAuth2.0_授权服务配置_客户端详情配置_Spring Security OAuth2.0认证授权---springcloud工作笔记142
    查看>>
    OAuth2.0_授权服务配置_密码模式及其他模式_Spring Security OAuth2.0认证授权---springcloud工作笔记145
    查看>>
    OAuth2.0_授权服务配置_授权码模式_Spring Security OAuth2.0认证授权---springcloud工作笔记144
    查看>>
    OAuth2.0_授权服务配置_资源服务测试_Spring Security OAuth2.0认证授权---springcloud工作笔记146
    查看>>
    OAuth2.0_环境介绍_授权服务和资源服务_Spring Security OAuth2.0认证授权---springcloud工作笔记138
    查看>>
    OAuth2.0_环境搭建_Spring Security OAuth2.0认证授权---springcloud工作笔记139
    查看>>
    oauth2.0协议介绍,核心概念和角色,工作流程,概念和用途
    查看>>