快捷搜索:  汽车  科技

spring mvc工作流程(SpringMVC运行流程)

spring mvc工作流程(SpringMVC运行流程)② 存在:c) 如果有配置,则执行目标资源(一般为静态资源,如:JSP HTML)① 不存在:a) 再判断是否配置了mvc:default-servlet-handler:b) 如果没配置,则控制台报映射查找不到,客户端展示404错误

SpringMVC运行流程:

spring mvc工作流程(SpringMVC运行流程)(1)

spring mvc工作流程(SpringMVC运行流程)(2)

spring mvc工作流程(SpringMVC运行流程)(3)

spring mvc工作流程(SpringMVC运行流程)(4)

spring mvc工作流程(SpringMVC运行流程)(5)


1) 用户向服务器发送请求,请求被SpringMVC 前端控制器 DispatcherServlet捕获;

2) DispatcherServlet对请求URL进行解析,得到请求资源标识符(URI):

判断请求URI对应的映射

① 不存在:

a) 再判断是否配置了mvc:default-servlet-handler:

b) 如果没配置,则控制台报映射查找不到,客户端展示404错误

c) 如果有配置,则执行目标资源(一般为静态资源,如:JSP HTML)

② 存在:

a) 执行下面流程

3) 根据该URI,调用HandlerMapping获得该Handler配置的所有相关的对象(包括Handler对象以及Handler对象对应的拦截器),最后以HandlerExecutionChain对象的形式返回;

4) DispatcherServlet 根据获得的Handler,选择一个合适的HandlerAdapter。

5) 如果成功获得HandlerAdapter后,此时将开始执行拦截器的preHandler(...)方法【正向】

6) 提取Request中的模型数据,填充Handler入参,开始执行Handler(Controller)方法,处理请求。在填充Handler的入参过程中,根据你的配置,Spring将帮你做一些额外的工作:

① HttpMessageConveter: 将请求消息(如Json、xml等数据)转换成一个对象,将对象转换为指定的响应信息

② 数据转换:对请求消息进行数据转换。如String转换成Integer、Double等

③ 数据根式化:对请求消息进行数据格式化。 如将字符串转换成格式化数字或格式化日期等

④ 数据验证: 验证数据的有效性(长度、格式等),验证结果存储到BindingResult或Error中

7) Handler执行完成后,向DispatcherServlet 返回一个ModelAndView对象;

8) 此时将开始执行拦截器的postHandle(...)方法【逆向】

9) 根据返回的ModelAndView(此时会判断是否存在异常:如果存在异常,则执行HandlerExceptionResolver进行异常处理)选择一个适合的ViewResolver(必须是已经注册到Spring容器中的ViewResolver)返回给DispatcherServlet,根据Model和View,来渲染视图

10) 在返回给客户端时需要执行拦截器的AfterCompletion方法【逆向】

11) 将渲染结果返回给客户端

SpringMVC实现文件下载方式:

@RequestMapping("testResponseEntity")

public ResponseEntity<byte[]> testResponseEntity(HttpSession session) throws IOException{

ServletContext servletContext = session.getServletContext();

InputStream resourceAsStream = servletContext.getResourceAsStream("/files/abc.txt");

byte[] body = new byte[resourceAsStream.available()] ;

resourceAsStream.read(body);

MultiValueMap<String String> headers = new HttpHeaders ();

headers.add ("Content-Disposition " "attachment;filename=abc.txt");

HttpStatus statusCode = HttpStatus.OK;

ResponseEntity<byte[]> responseEntity = new ResponseEntity<byte[]>(body headers statusCode);

return responseEntity ;

}


横切性关注点

AOP编程也就是基于上述描述推演开来。

1) 横切性关注点

我们加在主线业务前后的这些内容称为“横切性关注点”。根据OOP编程的原则,提供给多个地方调用的内容需要将它封装为一个方法,方法也不可能单独存在,需要存在一个类中,有此引出了后续概念。

2) 通知(advice)

将横向业务内容也即横切性关注点的内容封装为一个方法,这个方法称为“通知”advice

它可以放在主方法的前面(比如User里面的add方法是主方法而checkSecurity可以放在add方法前面后面等,均可)也可以放在后面。除此外还有异常通知、环绕通知和最终通知。

即被方法化的横切性关注点称为通知,它可以放在前后等多个地方。

3) 连接点(joinpoint)

就是那些被拦截到的点,spring这些点就是方法。也就是主线业务中的主要方法,每一

方法就是一个连接点,比如User类的CRUD四个方法,就是4个连接点。

4) 切入点(pointcut)

就是要对那些方法进行拦截,是对需要拦截的jonitpoint的定义。

5) 切面(aspect)

一个个封装了的方法称为advice,每一个方法均应该封装在一个类中;此外,在

这些advice上也需要定义将这些通知用于那些方法前面或者后面,这些定义也封装在这个类中,称为切入点,它们以后就作用于joinpoint将这些统一封装起来的类称为切面。公式表达:aspect=pointcut advice

6) 织入(weave)

将aspect运用到代理的目标对象上并导致proxy创建的过程称为织入。

猜您喜欢: