SpringMVC的基本原理


 1.在请求离开浏览器时 ,会带有用户所请求内容的信息,至少会包含请求的URL。但是还可 能带有其他的信息,例如用户提交的表单信息。
    2.请求旅程的第一站是Spring的 DispatcherServlet。与大多数基于Java的Web框架一样, Spring MVC所有的请求都会通过一个前端控制器(front controller)Servlet。前端控制器是常 用的Web应用程序模式,在这里一个单实例的Servlet将请求委托给应用程序的其他组件来执 行实际的处理。在Spring MVC中,DispatcherServlet就是前端控制器。 
    3.DispatcherServlet的任务是将请求发送给Spring MVC控制器(controller)。控制器是一个用于处理请求的Spring组件。在典型的应用程序中可能会有多个控制器,DispatcherServlet需要知道应该将请求发送给哪个控制器。 所以 DispatcherServlet以会查询一个或多个处理器映射(handler mapping) 来确定请求的 下一站在哪里。处理器映射会根据请求所携带的URL信息来进行决策。 
    4.一旦选择了合适的控制器,DispatcherServlet会将请求发送给选中的控制器 。到了控制器,请求会卸下其负载(用户提交的信息)并耐心 等待控制器处理这些信息。(实际上, 设计良好的控制器本身只处理很少甚至不处理工作,而是将业务逻辑委托给一个或多个服务对象进行处理。) 
    5.控制器在完成逻辑处理后,通常会产生一些信息,这些信息需要返回给用户并在浏览器上显示。这些信息被称为模型( model)。不过仅仅给用户返回原始的信息是不够的——这些信息需要以用户友好的方式进行格式化,一般会是HTML。所以,信息需要发送给一个视图 ( view),通常会是JSP。 
    6.控制器所做的最后一件事就是将模型数据打包,并且标示出用于渲染输出的视图名。它接下来会 将请求连同模型和视图名发送回DispatcherServlet 
    这样,控制器就不会与特定的视图相耦合,传递给Dispatcher-Servlet的视图名并不直 接表示某个特定的JSP。实际上,它甚至并不能确定视图就是JSP。相反,它 仅仅传递了一个逻辑名称,这个名字将会用来查找产生结果的真正视图。DispatcherServlet将会使用 视图解析器( view resolver) 来将逻辑视图名匹配为一个特定的视图实现,它可能是也可能不是JSP。
    7.既然DispatcherServlet已经知道由哪个视图渲染结果,那请求的任务基本上也就完成 了。它的最后一站是视图的实现(可能是JSP),在这里它交付模型数据。请求的任务就完成了。视图将使用模型数据渲染输出,这个输出会通过响应对象传递给客户端(不会像听上 去那样硬编码) 。

DispatcherServlet部分源码:




Spring整体架构:



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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值