3.SpringMVC

3.1 谈一下你对SpringMVC框架的理解

  • SpringMVC是一个基于Java的实现了MVC设计模式的请求驱动类型的轻量级Web框架,通过把Model,View,Controller分离,将web层进行职责解耦,把复杂的web应用分成逻辑清晰的几部分,简化开发,减少出错,方便组内开发人员之间的配合。
  • 在我看来,SpringMVC就是将我们原来开发在servlet中的代码拆分了,一部分由SpringMVC完成,一部分由我们自己完成

3.2 谈一下SpringMVC的执行流程以及各个组件的作用

  1. Request发送请求给前端控制器(dispatcherServlet)进行各个任务的调度
  2. dispatcherServlet根据浏览器请求的参数调用处理器映射器(HandlerMapping)进行参数查找
  3. HandlerMapping将查找后的结果返回给dispatcherServlet
  4. dispatcherServlet根据返回值调用处理器适配器(HandlerAdapter)
  5. HandlerAdapter根据参数调用处理器(Controller)
  6. Controller将得到的参数进行处理并返回结果给HandlerAdapter
  7. HandlerAdapyer将得到的结果返回给dispatcherServlet
  8. dispatcherServlet根据得到的参数调用视图解析器(ViewReslover)
  9. ViewReslover将得到的参数从逻辑视图转换为物理视图并返回给dispatcherServlet
  10. dispatcherServlet调用物理视图进行渲染并返回
  11. 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请求中文乱码问题?

  1. POST乱码:
    在web.xml中配置一个过滤器设置为utf-8就可以解决post提交方式的中文乱码问题;
  2. 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中所有学过的注解并标注其作用

  1. @Component @Controller @Service @Repository : 用于实例化对象
  2. @Scope : 设置Spring对象的作用域
  3. @PostConstruct @PreDestroy : 用于设置Spring创建对象在对象创建之后和销毁之前要执行的方法
  4. @Value: 简单属性的依赖注入
  5. @Autowired: 对象属性的依赖注入
  6. @Qualifier: 要和@Autowired联合使用,代表在按照类型匹配的基础上,再按照名称匹配。
  7. @Resource 按照属性名称依赖注入
  8. @ComponentScan: 组件扫描
  9. @Bean: 表在方法上,用于将方法的返回值对象放入容器
  10. @PropertySource: 用于引入其它的properties配置文件
  11. @Import: 在一个配置类中导入其它配置类的内容
  12. @Configuration: 被此注解标注的类,会被Spring认为是配置类。Spring在启动的时候会自动扫描并加载所有配置类,然后将配置 类中bean放入容器
  13. @RunWith: 用来Junit的切换运行器,用于整合junit测试
  14. ContextConfiguration: 和@RunWith配合使用, 向运行器传递配置文件的位置
  15. @Aspect: 表明当前类是一个切面
  16. @Pointcut("exectuion( ... )"): 注解在方法上,表示当前方法是一个切点,里面写入切点表达式
  17. @Before @After @AfterThrowing @AfterReturning @Around 通知注解
  18. @Transactional 此注解可以标在类上,也可以表在方法上,表示当前类中的方法具有事务管理功能。
  19. @EnableTransactionManagement 注解事务管理,等同于xml配置方式的 <tx:annotation-driven />
  20. @RequestMapping: 相当于为当前的方法绑定一个URL地址,可以与前端的请求相匹配。关注value 和 method 属性
  21. @RequestParam: 标注在方法参数之前,用于对传入的参数做一些限制,支持三个属性:
    • value:默认属性,用于指定前端传入的参数名称
    • required:用于指定此参数是否必传
    • defaultValue:当参数为非必传参数且前端没有传入参数时,指定一个默认值
  22. @RequestHeader 用于接收请求头中的所有信息,会封装到一个Map结构中去
  23. @RequestBody 用于接收请求体中的参数,并将其封装到对象中
  24. @ResponseBody 用于将方法的返回值放入响应体
  25. @PathVariable 用户从url路径上获取指定参数,标注在参数前 @PathVariabel("要获取的参数名")。
  26. @ControllerAdvice 标注在一个类上,表示该类是一个全局异常处理的类。
  27. @ExceptionHandler(Exception.class) 标注在异常处理类中的方法上,表示该方法可以处理的异常类型。