SpringWeb是个什么东西?SpringWeb是一个Java开发Web项目时的Web层框架。所谓Web层,就是直接和用户打交道的框架,用户(User)也就是顾客,顾客就是上帝,我们说是Web项目,通常也就是说B/S架构的项目,User通常也就是电脑或者手机中的浏览器之类的软件,或者说浏览器是真实用户、或者说上帝的化身吧。
上帝很厉害,用户的要求,通常都得满足。所以,SpringWeb在整个框架的架构中,就弄了一个东西,来专门负责和上帝打交道,这个东西就叫DispatcherServlet,通常我们称这个东西叫前端控制器。
DispatcherServlet:前端控制器
为什么叫控制器呢?因为负责整体的,用户或者上帝提出要求,接收请求的是它,对用户或上帝最终进行响应的,也是它。上帝很厉害,和上帝打交道的,必然也是厉害的角色,也就是它的权力或者说作用很大,或者说地位很高吧。
具体怎么讲呢?具体我们可以从SpringWeb的这个前端控制器的名称,也就是DispatcherServlet这个名称上可以看出来,DispatcherServlet的本质主要有两个,一个是它是基于Servlet实现的,另一个是它充当的具体身份或者角色,是一个Dispatcher,也就是调度员的角色,而所谓调度员,我们可以从企业经营或工厂生产的角度来理解,Dispatcher(调度员)通常相当于是公司领导或工厂领导的实际化身,是一种权力的象征,具体就是负责各种任务分配或生产调度的,是不是很厉害呀,人家是专门派任务的。
我们都知道,领导通常是不干实事的,Dispatcher这个东西,通常也是不干实事的,它就是派单、派任务的,具体的事实都是由别人来做,它只要结果,从某种意义上讲,它就是领导,就是上帝的化身。所以,Dispatcher也类似一个有钱人、一个富豪,什么事情都不自己干,都外包,它出钱,要干的事情出钱外包掉,他只要结果,当然,在这里DispatcherServlet,不是富豪,我们把它看成是一个权力的代表者,它不需要出钱,它只需要动用权力就可以了,而这个权力来自SpringWeb框架设计给它的定位。
现在,我们以一个具体的场景或需求来说一下DispatcherServlet这个Dispatcher,它是如何将任务外包出去的,是如何分派各种任务的,并是终接收各种结果,最终对用户(通常也就是浏览器)进行响应的。
上帝说,我缺个老婆,SpringWeb,你给我一个老婆吧。服务器这端的SpringWeb,就会找到DispatcherServlet来负责整件事情,DispatcherServlet作为领导或者说调度员,对于上帝提出的这种无理的要求(上帝怎么会缺老婆呢),但它必须满足,满足上帝的要求,但DispatcherServlet好歹也是一领导或领导的化身调度员,对不对?DispatcherServlet不可能去手搓一个花姑娘给上帝,他不可能亲自干这种体力活,对不对?那么办呢?
对于上帝的老婆,DispatcherServlet自己不会弄,他就得找手下弄,找专门生产花姑娘的工厂去生产,可是这么大一个领导(可能是集团公司哦),到底公司下面哪一个分公司或哪家工厂能干这件事情呢?DispatcherServlet并不清楚,于是DispatcherServlet会找来他的秘书,说秘书啊,我现在头疼,上帝要一老婆, 我现在好难呀,我们整个集团公司,哪个子公司或者下面哪个工厂能造一个机器人老婆给上帝啊,然后秘书就会告诉他找谁谁谁,这个DispatcherServlet的秘书,在整个SpringWeb架构中,就叫处理器映射器(HandlerMapping),而那个具体生产机器人老婆的工厂,就叫处理器(Handler),所以,DispatcherServlet听秘书(处理器映射器,HandlerMapping),一吨聒噪后,大体就知道找谁或哪个下面的子公司或工厂做老婆型机器人了,但通常,DispatcherServlet在联系下面做事情的时候,电话会先打到下面公司的管理层或生产部,最终具体是哪个工厂或车间去生产机器人,DispatcherServlet是不会管的,这个下面公司或子公司的管理层或生产部,在SpringWeb的整个架构中就叫处理器适配器(HandlerAdapter),而真正实质上执行老婆型机器人生产的工厂或车间,在SpringWeb中就是前面所说处理器(Handler)。
当工厂车间——也就是处理器(Handler),真正把机器人生产出来之后,其实是由生产部或车间的公司上层,也就是处理器适配器负责反馈给DispatcherServlet的,DispatcherServlet拿到老婆型机器人之后,一看,我靠,这机器人功能不错呀(想想能做老婆的机器人,功能自然很强大吧),但再一细思,这不对呀,这不行呀,这机器人就是几条棍棍加在一起呀,实在自己看着都难受,上帝会要这么个玩意当老婆?上帝应当是要一个花姑娘吧?所以,新的任务产生了,那就是把老婆型机器人再给包装包装、打扮打扮,最后发货回应给上帝后,自己才能睡个安稳觉吧,是于他又把这个任务,派给了自己下面的包装公司,这个包装公司,在SpringWeb架构中,就叫视图解析器(View Resolver)。
总之,SpringWeb相当于是一个星型结构的架构形式,类似于中央集权吧,权力中心的那个角色,就是DispatcherServlet,它被称为前端控制器,所以,它是个领导,是务虚的,人家专家负责给下面的人或子公司、机构分配或分派任务的,下面的人或机构,才是干实事的,就以上帝要老婆这个案例来说,其实最终真正干实事、负责核心业务的处理器(Handler),这个处理器(Handler)在实际的编程实践中,通常被命名为Controller,也就是控制器,所以,这个处理器(Handler)通常被称为SpringWeb的后端控制器。
当然,故事并没有就此结束,后来上帝说,这个机器人老婆不错,不过你们包装来包装去,就是给机器人披上几件漂亮的衣服而已,这件事情你们不用做了,你们给我个老婆型裸机器人就行,你们以为上帝的老婆还会缺几件漂亮的衣服不成?所以,后来就有了前后端彻底分离这么件事,SpringWeb基本也就不再干视图解析、数据渲染——给机器人化妆穿衣服这种事情了,因为上帝不需要了。