Spring MVC合集
@Controller和@RestController的区别?
返回值不同
@Controller返回的是一个视图,而@RestCobtroller返回的是一个对象
默认响应类型不同
@Controller默认响应类型是html,@RestController默认响应类型是JSON
使用场景不同
@Controller适合用于传统的web应用程序,而@RestController适合用于RESTful风格的web服务,尤其是前后端分离的web应用程序
Spring MVC常用的注解有哪些?
@Controller
用于标记一个类是Spring MVC的Controller,处理HTTP请求
@RequestMapping
用于映射http请求路径和请求方法
@PathVariable
用于获取请求url中的变量值
@RequestParam
用于获取请求参数的值
@ResponseBody
将Controller处理结果直接返回给客户端,而不是通过视图解析器进行视图渲染
@ModelAttribute
将请求参数绑定到Model中,使其在视图可以直接访问
@ExceptionHandler
用于定于全局异常处理方法
Spring MVC的主要组件有哪些?
DispatcherServlet
DispatcherServlet是Spring MVC的核心组件,负责接收客户请求,并将请求转发给对应的控制器。同时DispatcherServlet也负责处理异常、执行过滤器、视图解析和渲染任务等
HandleMapping
HandlerMapping负责将客户端请求映射到对应的控制器进行处理。也实现了RequestMappingHandlerMapping
Controller
Controller负责处理客户端请求,进行业务逻辑处理,并返回响应结果
ViewResolver
ViewResolver负责将控制器处理后返回的数据映射到对应的视图渲染
ModelAndView
封装控制器返回的数据和视图
HandlerInterceptor
HandlerInterceptor负责在请求处理前、请求处理后和视图渲染前拦截请求
Spring MVC的理解
组成
Spring MVC是Spring Framework的一部分
特点
灵活性
Spring MVC采用松耦合的设计,允许开发人员根据自己的需求来选择使用哪些组件
可扩产性
Spring MVC提供了很多扩展点,是开发人员轻松的添加自己的功能
高能性
Spring MVC采用基于注解的控制器(Controller),避免XML配置文件的解析和加载
安全性
Spring MVC提供了很多种安全机制,可以有效地保护应用程序的安全
采用MVC模式
模型
表示应用程序的数据和业务逻辑,有javaBean组成,被控制器用于处理用户请求
视图
是用户界面,通常是一个html页面,用来展现模型中的数据
控制器
是应用程序的核心,负责接收和处理用户请求,并将请求转发给模型和视图,将处理结果返回给客户端
应用场景
RESTful服务
前后端分离
Spring MVC怎么实现过滤器或者拦截器
过滤器
通过实现javax.servlet.Filter接口来实现过滤器。需要在web.xml中配置过滤器,即在<filter>标签中配置<filter-name>和<filter-class>,并在<filter-mapping>标签中配置过滤器的映射路径和顺序。
拦截器
通过实现org.springframework.web.servlet.HandlerInterceptor接口来实现拦截器。需要在Spring MVC配置文件中配置拦截器,即在mvc:interceptors标签中配置<bean>,并设置拦截器的顺序和映射路径。
用户请求到springMVC处理流程
1.用户发起请求
2. DispatcherServlet接收请求
3. HandlerMapping进行请求映射
4. Controller处理请求
5.Controller返回ModelAndView
6. DispatcherServle将ModolAndView交给ViewResolver进行视图解析
7. View进行视图渲染
8. DispatcherServlet将渲染结果返回给客户端