3.SpringMVC
3.1 谈一下你对SpringMVC框架的理解
- SpringMVC是一个基于Java的实现了MVC设计模式的请求驱动类型的轻量级Web框架,通过把Model,View,Controller分离,将web层进行职责解耦,把复杂的web应用分成逻辑清晰的几部分,简化开发,减少出错,方便组内开发人员之间的配合。
- 在我看来,SpringMVC就是将我们原来开发在servlet中的代码拆分了,一部分由SpringMVC完成,一部分由我们自己完成
3.2 谈一下SpringMVC的执行流程以及各个组件的作用
- Request发送请求给前端控制器(dispatcherServlet)进行各个任务的调度
- dispatcherServlet根据浏览器请求的参数调用处理器映射器(HandlerMapping)进行参数查找
- HandlerMapping将查找后的结果返回给dispatcherServlet
- dispatcherServlet根据返回值调用处理器适配器(HandlerAdapter)
- HandlerAdapter根据参数调用处理器(Controller)
- Controller将得到的参数进行处理并返回结果给HandlerAdapter
- HandlerAdapyer将得到的结果返回给dispatcherServlet
- dispatcherServlet根据得到的参数调用视图解析器(ViewReslover)
- ViewReslover将得到的参数从逻辑视图转换为物理视图并返回给dispatcherServlet
- dispatcherServlet调用物理视图进行渲染并返回
- dispatcherServlet将渲染后的结果返回
3.3 说一下SpringMVC支持的转发和重定向的写法
1)转发:
简单方式:直接return "要跳转的页面"
forward方式:在返回值前面加"forward:",比如"forward:user.do?name=method4"
原生方式:使用原生的方法通过request直接转发
2) 重定向:
redirect方式:在返回值前面加”redirect:”,比如”redirect:http://baidu.com”
原生方式:使用原生的方法通过response直接转发
3.4 谈一下SpringMVC统一异常处理的思想和实现方式
使用SpringMVC之后,代码的调用者是SpringMVC框架,也就是说最终的异常会抛到框架中,然后由框架指定异常处理类进行统一处理
- 方式一: 创建一个自定义异常处理器(实现HandlerExceptionResolver接口),并实现里面的异常处理方法,然后将这个类交给Spring容器管理
- 方式二 在类上加注解(@ControllerAdvice)表明这是一个全局异常处理类
在方法上加注解(@ExceptionHandler),在ExceptionHandler中有一个value属性,可以指定可以处理的异常类型
3.5 在SpringMVC中, 如果想通过转发将数据传递到前台,有几种写法?
- 方式一:直接使用request域进行数据的传递
request.setAttirbuate("name", value); - 方式二:使用Model进行传值,底层会将数据放入request域进行数据的传递
model.addAttribuate("name", value); - 方式三:使用ModelMap进行传值,底层会将数据放入request域进行数据的传递
modelmap.put("name",value); - 方式四:借用ModelAndView在其中设置数据和视图
mv.addObject("name",value);
mv.setView("success");
return mv;
3.6 在SpringMVC中拦截器的使用步骤是什么样的?
- 1 定义拦截器类:
SpringMVC为我们提供了拦截器规范的接口,创建一个类实现HandlerInterceptor,重写接口中的抽象方法;
preHandle方法:在调用处理器之前调用该方法,如果该方法返回true则请求继续向下进行,否则请求不会继续向下进行,处理器也不会调用
postHandle方法:在调用完处理器后调用该方法
afterCompletion方法:在前端控制器渲染页面完成之后调用此方法 - 2 注册拦截器:
在SpringMVC核心配置文件中注册自定义的拦截器<mvc:interceptors> <mvc:interceptor> <mvc:mapping path="拦截路径规则"/> <mvc:exclude-mapping path="不拦截路径规则"/> <bean class="自定义拦截器的类全限定名"/> </mvc:interceptor> </mvc:interceptors>
3.7 在SpringMVC中文件上传的使用步骤是什么样的? 前台三要素是什么?
- 文件上传步骤:
1.加入文件上传需要的commons-fileupload包
2.配置文件上传解析器,springmvc的配置文件的文件上传解析器的id属性必须为multipartResolver
3.后端对应的接收文件的方法参数类型必须为MultipartFile,参数名称必须与前端的name属性保持一致 - 文件上传前端三要素:
1.form表单的提交方式必须为post
2.enctype属性需要修改为:multipart/form-data
3.必须有一个type属性为file的input标签,其中需要有一个name属性;如果需要上传多个文件需要添加multiple属性
3.8 Springmvc 中如何解决 GET | POST请求中文乱码问题?
- POST乱码:
在web.xml中配置一个过滤器设置为utf-8就可以解决post提交方式的中文乱码问题; - GET乱码:
第一种可以修改tomcat配置文件,添加编码与工程编码一致;
第二种方法是对请求携带的参数进行重新编码,将tomcat编码后的内容按utf-8编码
3.9 在SpringMVC的方法参数中,我们在方法形参位置,直接问Spring要的数据类型有哪些?
1)简单类型:8+8+1(byte short char int long double float boolean 及其对应的包装类 + String)
2)对象类型: 要保证前端传递的参数名称跟实体的属性名称
3)数组类型: 要保证前端传递的参数名称跟方法中的数组形参名称一致
4)集合类型: 要将集合参数包装到一个实体中
5)格式比较灵活的类型,如日期类型时间类型:这时候需要自定义一个类型转换器并且声明转换服务,再将转换器对象注册到服务;
6)文件类型:配置文件上传解析器,前端页面必须满足文件上传三要素。
7) 内置对象:HttpServletRequest HttpServletResponse HttpSession Model ModelMap ModelAndView
4.注解
列出Spring和SpringMVC中所有学过的注解并标注其作用
- @Component @Controller @Service @Repository : 用于实例化对象
- @Scope : 设置Spring对象的作用域
- @PostConstruct @PreDestroy : 用于设置Spring创建对象在对象创建之后和销毁之前要执行的方法
- @Value: 简单属性的依赖注入
- @Autowired: 对象属性的依赖注入
- @Qualifier: 要和@Autowired联合使用,代表在按照类型匹配的基础上,再按照名称匹配。
- @Resource 按照属性名称依赖注入
- @ComponentScan: 组件扫描
- @Bean: 表在方法上,用于将方法的返回值对象放入容器
- @PropertySource: 用于引入其它的properties配置文件
- @Import: 在一个配置类中导入其它配置类的内容
- @Configuration: 被此注解标注的类,会被Spring认为是配置类。Spring在启动的时候会自动扫描并加载所有配置类,然后将配置 类中bean放入容器
- @RunWith: 用来Junit的切换运行器,用于整合junit测试
- ContextConfiguration: 和@RunWith配合使用, 向运行器传递配置文件的位置
- @Aspect: 表明当前类是一个切面
- @Pointcut("exectuion( ... )"): 注解在方法上,表示当前方法是一个切点,里面写入切点表达式
- @Before @After @AfterThrowing @AfterReturning @Around 通知注解
- @Transactional 此注解可以标在类上,也可以表在方法上,表示当前类中的方法具有事务管理功能。
- @EnableTransactionManagement 注解事务管理,等同于xml配置方式的 <tx:annotation-driven />
- @RequestMapping: 相当于为当前的方法绑定一个URL地址,可以与前端的请求相匹配。关注value 和 method 属性
- @RequestParam: 标注在方法参数之前,用于对传入的参数做一些限制,支持三个属性:
- value:默认属性,用于指定前端传入的参数名称
- required:用于指定此参数是否必传
- defaultValue:当参数为非必传参数且前端没有传入参数时,指定一个默认值
- @RequestHeader 用于接收请求头中的所有信息,会封装到一个Map结构中去
- @RequestBody 用于接收请求体中的参数,并将其封装到对象中
- @ResponseBody 用于将方法的返回值放入响应体
- @PathVariable 用户从url路径上获取指定参数,标注在参数前 @PathVariabel("要获取的参数名")。
- @ControllerAdvice 标注在一个类上,表示该类是一个全局异常处理的类。
- @ExceptionHandler(Exception.class) 标注在异常处理类中的方法上,表示该方法可以处理的异常类型。