12.16 SpringMVC 面试题
参考治疗:https://thinkwon.blog.csdn.net/article/details/104397427
-
什么是Spring MVC
-
Spring MVC是一个基于Java的实现了MVC设计模式的请求驱动类型的轻量级Web框架,通过把模型-视图-控制器分离,将web层进行职责解耦,把复杂的web应用分成逻辑清晰的几部分,简化开发,减少出错,方便组内开发人员之间的配合
-
核心组件
-
前端控制器 DispatcherServlet(不需要程序员开发)
-
Spring的MVC框架是围绕DispatcherServlet来设计的,它用来处理所有的HTTP请求和响应。
-
作用:接收请求、响应结果,相当于转发器,有了DispatcherServlet 就减少了其它组件之间的耦合度。
-
处理器映射器HandlerMapping(不需要程序员开发)
-
作用:根据请求的URL来查找Handler
-
处理器适配器HandlerAdapter
-
注意:在编写Handler的时候要按照HandlerAdapter要求的规则去编写,这样适配器HandlerAdapter才可以正确的去执行Handler。
-
处理器Handler(需要程序员开发)
-
视图解析器 ViewResolver(不需要程序员开发)
-
作用:进行视图的解析,根据视图逻辑名解析成真正的视图(view)
-
视图View(需要程序员开发jsp)
-
View是一个接口, 它的实现类支持不同的视图类型(jsp,freemarker,pdf等等)
-
Spring MVC控制器
-
控制器提供一个访问应用程序的行为,此行为通常通过服务接口实现。控制器解析用户输入并将其转换为一个由视图呈现给用户的模型。Spring用一个非常抽象的方式实现了一个控制层,允许用户创建多种用途的控制器。
-
控制器是单例模式,所以在多线程访问的时候有线程安全问题,不要用同步,会影响性能的,解决方案是在控制器里面不能写字段。
-
有哪些优缺点
-
可以支持各种视图技术,而不仅仅局限于JSP;
-
与Spring框架集成(如IoC容器、AOP等);
-
清晰的角色分配:前端控制器(dispatcherServlet) , 请求到处理器映射(handlerMapping), 处理器适配器(HandlerAdapter), 视图解析器(ViewResolver)。
-
支持各种请求资源的映射策略
-
实现场景:前后端分离的项目
-
实现原理,Spring MVC的工作流程? DispatcherServlet 的工作流程?
-
用户发送请求至前端控制器DispatcherServlet;
-
DispatcherServlet收到请求后,调用HandlerMapping处理器映射器,请求获取Handle;
-
处理器映射器根据请求url找到具体的处理器,生成处理器对象及处理器拦截器(如果有则生成)一并返回给DispatcherServlet;
-
DispatcherServlet 调用 HandlerAdapter处理器适配器;
-
HandlerAdapter 经过适配调用 具体处理器(Handler,也叫后端控制器);
-
Handler执行完成返回ModelAndView;
-
HandlerAdapter将Handler执行结果ModelAndView返回给DispatcherServlet;
-
DispatcherServlet将ModelAndView传给ViewResolver视图解析器进行解析;
-
ViewResolver解析后返回具体View;
-
DispatcherServlet对View进行渲染视图(即将模型数据填充至视图中)
-
DispatcherServlet响应用户。
-
MVC框架,MVVC框架
-
mvc是一种设计模式(设计模式就是日常开发中编写代码的一种好的方法和经验的总结)。模型(model)-视图(view)-控制器(controller),三层架构的设计模式。用于实现前端页面的展现与后端业务数据处理的分离。
-
优点
-
1.分层设计,实现了业务系统各个组件之间的解耦,有利于业务系统的可扩展性,可维护性。
-
2.有利于系统的并行开发,提升开发效率。
-
缺点
-
总结:所谓的MVC ,用户操作> View (负责接受用户的输入操作)>Controller(业务逻辑处理)>Model(数据持久化)>View(将结果通过View反馈给用户)
-
MVVC
-
Mvc中Controller演变成mvvm中的viewModel。
-
viewModel一是将模型(Model)转化成视图(View),即将后端传递的数据转化成所看到的页面。实现的方式是:数据绑定。二是将视图(View)转化成模型(Model),即将所看到的页面转化成后端的数据。实现的方式是:DOM 事件监听。这两个方向都实现的,我们称之为数据的双向绑定。
-
ViewModel存在目的在于抽离Controller中展示的业务逻辑,而不是替代Controller,其它视图操作业务等还是应该放在Controller中实现。也就是说MVVM实现的是业务逻辑组件的重用,使开发更高效,结构更清晰,增加代码的复用性。
-
mvvm主要解决了mvc中大量的DOM 操作使页面渲染性能降低,加载速度变慢,影响用户体验。
-
当 Model 频繁发生变化,开发者需要主动更新到View的问题 。
-
总结:MVVM是将“数据模型数据双向绑定”的思想作为核心,因此在View和Model之间没有联系,通过ViewModel进行交互,而且Model和ViewModel之间的交互是双喜那个的,因此试图的数据的变化会同事修改数据源,而数据源数据的变化也会立即反应到View上。
-
常用的注解
-
注解的原理是什么
-
注解本质是一个继承了Annotation的特殊接口,其具体实现类是Java运行时生成的动态代理类。我们通过反射获取注解时,返回的是Java运行时生成的动态代理对象。通过代理对象调用自定义注解的方法,会最终调用AnnotationInvocationHandler的invoke方法。该方法会从memberValues这个Map中索引出对应的值。而memberValues的来源是Java常量池。
-
常用注解有那些
-
@RequestMapping:用于处理请求 url 映射的注解,可用于类或方法上。用于类上,则表示类中的所有响应请求的方法都是以该地址作为父路径。
-
RequestMapping是一个用来处理请求地址映射的注解,可用于类或方法上。用于类上,表示类中的所有响应请求的方法都是以该地址作为父路径。
-
RequestMapping注解有六个属性
-
value: 指定请求的实际地址,指定的地址可以是URI Template 模式(后面将会说明);
-
method: 指定请求的method类型, GET、POST、PUT、DELETE等;
-
consumes: 指定处理请求的提交内容类型(Content-Type),例如application/json, text/html;
-
produces: 指定返回的内容类型,仅当request请求头中的(Accept)类型中包含该指定类型才返回;
-
params: 指定request中必须包含某些参数值是,才让该方法处理。
-
headers: 指定request中必须包含某些指定的header值,才能让该方法处理请求。
-
@RequestBody:注解实现接收http请求的json数据,将json转换为java对象。
-
该注解用于将Controller的方法返回的对象,通过适当的HttpMessageConverter转换为指定格式后,写入到Response对象的body数据区。
-
使用时机:返回的数据不是html标签的页面,而是其他某种格式的数据时(如json、xml等)使用;
-
@ResponseBody:注解实现将conreoller方法返回对象转化为json对象响应给客户。
-
控制器
-
SpingMvc中的控制器的注解@Controller,也可以使用@RestController,@RestController注解相当于@ResponseBody + @Controller,表示是表现层,除此之外,一般不用别的注解代替。
-
@RestController注解
-
Controller
-
Controller 用于标记在一个类上,使用它标记的类就是一个Spring MVC Controller 对象。分发处理器将会扫描使用了该注解的类的方法,并检测该方法是否使用了@RequestMapping 注解。@Controller 只是定义了一个控制器类,而使用@RequestMapping 注解的方法才是真正处理请求的处理器。
-
单单使用@Controller 标记在一个类上还不能真正意义上的说它就是Spring MVC 的一个控制器类,因为这个时候Spring 还不认识它。那么要如何做Spring 才能认识它呢?这个时候就需要我们把这个控制器类交给Spring 来管理。
-
在Spring MVC 的配置文件中定义MyController 的bean 对象。
-
在Spring MVC 的配置文件中告诉Spring 该到哪里去找标记为@Controller 的Controller 控制器
-
常见面试题
-
Spring MVC与Struts2区别
-
相同点:
-
都是基于mvc的视图层框架,都用于web项目的开发。
-
不同点
-
前端控制器不一样。Spring MVC的前端控制器是servlet:DispatcherServlet。struts2的前端控制器是filter:StrutsPreparedAndExcutorFilter。
-
请求参数的接收方式不一样。Spring MVC是使用方法的形参接收请求的参数,基于方法的开发,线程安全,可以设计为单例或者多例的开发,推荐使用单例模式的开发(执行效率更高),默认就是单例开发模式。struts2是通过类的成员变量接收请求的参数,是基于类的开发,线程不安全,只能设计为多例的开发。
-
Struts采用值栈存储请求和响应的数据,通过OGNL存取数据,Spring MVC通过参数解析器是将request请求内容解析,并给方法形参赋值,将数据和视图封装成ModelAndView对象,最后又将ModelAndView中的模型数据通过reques域传输到页面。Jsp视图解析器默认使用jstl。
-
与spring整合不一样。Spring MVC是spring框架的一部分,不需要整合。在企业项目中,Spring MVC使用更多一些
-
Spring MVC怎么样设定重定向和转发的?
-
转发:在返回值前面加"forward:",譬如"forward:user.do?name=method4"
-
重定向:在返回值前面加"redirect:",譬如"redirect:http://www.baidu.com"
-
如何解决POST请求中文乱码问题,GET的又如何处理呢?
-
解决post请求乱码问题:在web.xml中配置一个CharacterEncodingFilter过滤器,设置成utf-8;
-
get请求中文参数出现乱码解决方法有两个:
-
修改tomcat配置文件添加编码与工程编码一致
-
另外一种方法对参数进行重新编码:
-
Spring MVC的异常处理?
-
可以将异常抛给Spring框架,由Spring框架来处理;我们只需要配置简单的异常处理器,在异常处理器中添视图页面即可。
-
拦截相关
-
拦截get方式提交的方法:可以在@RequestMapping注解里面加上method=RequestMethod.GET
-
在方法里面得到Request,或者Session?
-
直接在方法的形参中声明request,Spring MVC就自动把request对象传入。
-
想在拦截的方法里面得到从前台传入的参数,怎么得到?
-
直接在形参里面声明这个参数就可以,但必须名字和传过来的参数一样
-
前台有很多个参数传入,并且这些参数都是一个对象的,那么怎么样快速得到这个对象
-
前台有很多个参数传入,并且这些参数都是一个对象的,那么怎么样快速得到这个对象
-
Spring MVC中函数的返回值
-
返回值可以有很多类型,有String, ModelAndView。ModelAndView类把视图和数据都合并的一起的,但一般用String比较好。
-
Spring MVC用什么对象从后台向前台传递数据
-
通过ModelMap对象,可以在这个对象里面调用put方法,把对象加到里面,前台就可以通过el表达式拿到
-
怎么样把ModelMap里面的数据放入Session里面
-
可以在类上面加上@SessionAttributes注解,里面包含的字符串就是要放入session里面的key
-
拦截器写法
-
一种是实现HandlerInterceptor接口,
-
另外一种是继承适配器类,接着在接口方法当中,实现处理逻辑;然后在Spring MVC的配置文件中配置拦截器即可:
-
WebApplicationContext
-
WebApplicationContext 继承了ApplicationContext 并增加了一些WEB应用必备的特有功能,它不同于一般的ApplicationContext ,因为它能处理主题,并找到被关联的servlet。
努力不一定成功,但不努力一定会失败~