struts 2 的运作流程介绍及分析(使用纯servlet模拟)

2024-04-06 08:58

本文主要是介绍struts 2 的运作流程介绍及分析(使用纯servlet模拟),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

   国庆整理: struts2 的运作流程分析: 
附件有整个demo的源代码:哟呵哦。。没找到附件这个东东,我去,是csdn博客没有这个吗??;
算了,发百度网盘分享好了:http://pan.baidu.com/share/link?shareid=915432945&uk=2150127573 (发这连接不会被封吧。。╮(╯▽╰)╭)
使用servlet 来写一个struts 2  流程的demo,来好好的分析:

  Struts 2是Struts的下一代产品,是在 struts 1和WebWork的技术基础上进行了合并的全新的Struts 2框架。其全新的Struts 2的 体系结构 与Struts 1的体系结构差别巨大。Struts 2以WebWork为 核心 ,采用拦截器的机制来处理用户的请求,这样的设计也使得业务逻辑控制器能够与 Servlet API完全脱离开,所以Struts 2可以理解为WebWork的更新产品。虽然从Struts 1到Struts 2有着太大的 变化 ,但是相对于WebWork,Struts 2的变化很小。
struts 2 就是一个mvc模式的非侵入式web框架;
下面是struts的 运行流程 图;

根据以上的流程,写一个类似的一个struts的框架,(只是实现以上的基本流程,有很多的限制);
首先,先给出框架源代码文件结构:

以及用到的jar:

一些局限的限制:
1、只支持注解
2、自动类型转换没有了
3、action的请求后缀,只能是.action。比如:hello.action
4、规定action类只能放到包名为:com.bjsxt.action包下  

    上面已经介绍了,框架的文件组成,下面就不显示代码了,就分析就好了,代码太多,而且一些的方法一不懂具体的功能,就只能简单的使用,所以就没有办法解释什么的了。

开始了:
  • 启动tomacat 的时候,打印的东东:
    
Filter 初始化 解析xml 的拦截器 加到 map
Filter中调用proxy的构造方法
proxy的构造函数被调用 开始 遍历所有的action 添加注解 class map
分析:
    项目启动的时候,过滤器的初始化方法(init())被调用,方法中解析配置文件struts.xml文件,解析得到拦截器的 名称类(全限定名);并添加到ActionMapper类中的对应列表中;
    然后,调用ActionProxy类的构造方法,作用是 遍历 框架项目中的所有符合的 Action,获得其 注解的 名字类(全由限定名加载得到的);
    这样就完成了,项目的初始化了,把 项目里面的所有的配置的Action都写到列表里面的,这样就方便后面的操作了。主要的的信息就是Action和intercept这两个了;
  • 访问一个action:
    
请求拦截 开始 处理。。。。。
拿到请求的 类名 和方法名:test1hello
map中找到对应的类 。。。filter开始调用actionProxy.execute方法
actionProxy.execute方法被调用 开始创建 action实例 并执行对应的拦截器 放回方法返回值
得到拦截器列表 proxy构建执行ActionInvocation
ActionInvocation类被初始化。。。。。。
ActionInvocationinvoke方法被调用 。。。开始执行拦截器列表
递归调用 拦截器
执行拦截器1
ActionInvocationinvoke方法被调用 。。。开始执行拦截器列表
递归调用 拦截器
执行拦截器2
ActionInvocationinvoke方法被调用 。。。开始执行拦截器列表
拦截器列表 已经为空 表示拦截器递归执行结束 ,开始执行action
调用action中的方法
结束执行连接器2
结束执行连接器1
已经调用action类的方法,并得到返回值了 。。开始解析返回值
分析:
    请求发送后,被过滤器拦截下来,对请求进行相应的处理:
         从请求中取得请求的 文件名(既类名) 和 方法名 ;(这个类名是别名 在 注解里面设置的,这个的信息在Actionmapper中);所以要使用类中的对应方法来查找这个 名字是否存在,如果不存在就是没有了 返回404就可以了,如果存在,就要进行下面的处理了;
    调用proxy的 execute方法,其会放射action,把action内引用的所有拦截器添加到一个拦截器list列表中,并构建调用 ActionInvocation类来执行拦截器和action   (参数中把 action个拦截器list传过去了);
     ActionInvocation 类先执行拦截器,其是 递归调用的 ,让后执行action方法,并放回结果;这个结果会放回到监听类中(一层一层放回回去的);
    最后在拦截器里,对返回的字符串进行分析,就是解析result注解,进行对应匹配字符,让后请求转发到对应的result地址去,就结束了这个流程;

    在整个的流程中,多次的解析配置和注解,(初始化时解析配置文件,遍历action;加载action是解析注解引用的拦截器;返回是解析注解的result),这些的操作会用到dom4j,ognl的技术,具体的实现方法用到了  类和方法的反射机制 ,具体的代码就直接看项目源码就可以了;还有老师写的(是一样的,自己的有注释,有一些过程进度的输出,可以看到运作流程),都在附件里面了;

​这个的框架,自己写是不可能的,就这么一个简单的流程框架实现其来就要这么麻烦,要是吧那些限制去掉,就要有很多的可能,这行可能都要编写代码来处理,还用struts最重要的核心的技术就是拦截器,这个东东的作用是相当的大,基本上在用struts是和使用servlet中被简化被省略的东东都是由拦截器来处理的,在struts的配置文件中,默认引用的拦截器就有十几个,可想而知,这东东是多呢的牛掰了。
所以,对于我这个写的东东就是用来简单理解想流程的,里面的实现就感觉不是很好了,具体的东东还是要去看struts的源码,不过那东东不是一点的多啊。。。。。。




















这篇关于struts 2 的运作流程介绍及分析(使用纯servlet模拟)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/879522

相关文章

Security OAuth2 单点登录流程

单点登录(英语:Single sign-on,缩写为 SSO),又译为单一签入,一种对于许多相互关连,但是又是各自独立的软件系统,提供访问控制的属性。当拥有这项属性时,当用户登录时,就可以获取所有系统的访问权限,不用对每个单一系统都逐一登录。这项功能通常是以轻型目录访问协议(LDAP)来实现,在服务器上会将用户信息存储到LDAP数据库中。相同的,单一注销(single sign-off)就是指

Spring Security基于数据库验证流程详解

Spring Security 校验流程图 相关解释说明(认真看哦) AbstractAuthenticationProcessingFilter 抽象类 /*** 调用 #requiresAuthentication(HttpServletRequest, HttpServletResponse) 决定是否需要进行验证操作。* 如果需要验证,则会调用 #attemptAuthentica

性能测试介绍

性能测试是一种测试方法,旨在评估系统、应用程序或组件在现实场景中的性能表现和可靠性。它通常用于衡量系统在不同负载条件下的响应时间、吞吐量、资源利用率、稳定性和可扩展性等关键指标。 为什么要进行性能测试 通过性能测试,可以确定系统是否能够满足预期的性能要求,找出性能瓶颈和潜在的问题,并进行优化和调整。 发现性能瓶颈:性能测试可以帮助发现系统的性能瓶颈,即系统在高负载或高并发情况下可能出现的问题

中文分词jieba库的使用与实景应用(一)

知识星球:https://articles.zsxq.com/id_fxvgc803qmr2.html 目录 一.定义: 精确模式(默认模式): 全模式: 搜索引擎模式: paddle 模式(基于深度学习的分词模式): 二 自定义词典 三.文本解析   调整词出现的频率 四. 关键词提取 A. 基于TF-IDF算法的关键词提取 B. 基于TextRank算法的关键词提取

水位雨量在线监测系统概述及应用介绍

在当今社会,随着科技的飞速发展,各种智能监测系统已成为保障公共安全、促进资源管理和环境保护的重要工具。其中,水位雨量在线监测系统作为自然灾害预警、水资源管理及水利工程运行的关键技术,其重要性不言而喻。 一、水位雨量在线监测系统的基本原理 水位雨量在线监测系统主要由数据采集单元、数据传输网络、数据处理中心及用户终端四大部分构成,形成了一个完整的闭环系统。 数据采集单元:这是系统的“眼睛”,

使用SecondaryNameNode恢复NameNode的数据

1)需求: NameNode进程挂了并且存储的数据也丢失了,如何恢复NameNode 此种方式恢复的数据可能存在小部分数据的丢失。 2)故障模拟 (1)kill -9 NameNode进程 [lytfly@hadoop102 current]$ kill -9 19886 (2)删除NameNode存储的数据(/opt/module/hadoop-3.1.4/data/tmp/dfs/na

Hadoop数据压缩使用介绍

一、压缩原则 (1)运算密集型的Job,少用压缩 (2)IO密集型的Job,多用压缩 二、压缩算法比较 三、压缩位置选择 四、压缩参数配置 1)为了支持多种压缩/解压缩算法,Hadoop引入了编码/解码器 2)要在Hadoop中启用压缩,可以配置如下参数

Makefile简明使用教程

文章目录 规则makefile文件的基本语法:加在命令前的特殊符号:.PHONY伪目标: Makefilev1 直观写法v2 加上中间过程v3 伪目标v4 变量 make 选项-f-n-C Make 是一种流行的构建工具,常用于将源代码转换成可执行文件或者其他形式的输出文件(如库文件、文档等)。Make 可以自动化地执行编译、链接等一系列操作。 规则 makefile文件

性能分析之MySQL索引实战案例

文章目录 一、前言二、准备三、MySQL索引优化四、MySQL 索引知识回顾五、总结 一、前言 在上一讲性能工具之 JProfiler 简单登录案例分析实战中已经发现SQL没有建立索引问题,本文将一起从代码层去分析为什么没有建立索引? 开源ERP项目地址:https://gitee.com/jishenghua/JSH_ERP 二、准备 打开IDEA找到登录请求资源路径位置

使用opencv优化图片(画面变清晰)

文章目录 需求影响照片清晰度的因素 实现降噪测试代码 锐化空间锐化Unsharp Masking频率域锐化对比测试 对比度增强常用算法对比测试 需求 对图像进行优化,使其看起来更清晰,同时保持尺寸不变,通常涉及到图像处理技术如锐化、降噪、对比度增强等 影响照片清晰度的因素 影响照片清晰度的因素有很多,主要可以从以下几个方面来分析 1. 拍摄设备 相机传感器:相机传