JFinal框架源码分析(二)——JFinal控制器

【前面一节jfinal ——Handler 之 责任链模式(chain of Responsibility)

前言:

源码的分析是件非常考验耐性和分析能力的苦力活,但是又是码农翻身必经的一步。如果没有掌握一定的方法,相信我,你会立马关掉你的IDE。
第一步:建立宏观面,这一步只需要了解就final大致的功能、架构、应用场景即可。
第二步:确定范围,你要知道,要是不提前确定分析问题的边界,你这个web源码分析能够追溯到操作内核的二进制码。
第三步:明确分析的目标,在确定问题边界的基础上,进一步明确分析的jfinal框架研究的主体内容。这个具体关系到个人的知识结构,可能你的目标是java高级语法的使用方式、MVC架构的思想、AOP编程思想及其实现或是某个设计模式的使用.....
第四步:分解目标,逐个击破,没什么好说的,要的就是坚持,试着在解决问题之前提出自己的疑惑。当然小目标不断地迭代这个过程【重复步骤1-4】。
接下来看我操作↓:

提出问题:

如何写一个自定义的jfinal控制器?

Jfinal控制器又是如何处理客户端的请求的?

关于控制器Controller的类图分析

733795-20190131164103795-2041695420.png

用户自定义的控制器(DemoController)继承Controller方法:

Controller对象由动态ControllerFactory创建:
733795-20190131164114382-1229136764.png

每实例化一个Controller对象都会有一个相对应的Action对象与之对应。

而ActionHandler、ActionReporter、ActionMapping对应。

用户自定义的控制器的写法
733795-20190131164125737-1696598105.png

Jfinal控制器如何处理客户端的请求

733795-20190131164133899-587367359.png

前面一节在JFinal框架源码分析(一)——JFinal项目的启动已经分析了jfinal项目的启动过程,这里不再赘述。
接下来将重点关注客户端的请求是如何加载controller类的。
项目启动,初始化对象,包括ActionHandler
733795-20190131164154991-1724163283.png

ActionHandler通过反射机制加载Controller。
733795-20190131164203965-659912883.png

整个Controller的加载过程已经实现,具体细节需要跟踪调试源码,步进断点,停留取值。

转载于:https://www.cnblogs.com/Erma/p/10342622.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值