springmvc默认方法名为映射名_SpringMVC学习要点--十分钟帮你快速掌握框架核心

《“爱读书”--给你讲技术》,我来看书,你来进步,让我们开始吧!

本书简介

书名为《Spring+MyBatis企业应用实战》,是本人在学习JavaEE框架时候的一本基础书籍,本书对于SpringMVC和MyBatis框架及相关基础知识讲述的比较清晰,适合需要详细学习Java框架的读者。

1bbf3df7d7cd40518c0969532e6c39a2

本文内容为本书第二章--第八章,记录和总结了所有SpringMVC的知识

99903497c7ba4f2b89edeaf5563b6521

DispatcherServlet

1.DispatcherServlet使用和配置

SpringMVC提供了一个名为org.springframework.web.servlet.DispatcherServlet的Servlet充当前端控制器,所有请求驱动都围绕这个DispatcherServlet来分配请求。DispatcherServlet是一个Servlet类,需要在web.xml中完成配置。

7636031c568640cda9a7b5219de35ccd

(1)配置了启动时立即加载Servlet

(2)需要配置springmvc-config.xml配置文件

(3)配置了用当前servlet处理所有请求URL

2.DispatcherServlet的分发原理

先看一下DispatcherServlet源码中的方法

源码如下:

69caff8bd6dd49acaed38051c509917a

initStrategies方法将在WebApplicationContext初始化后自动执行,自动扫描上下文的Bean,根据名称或类型匹配机制查找自定义的组件。如果没有找到则会装配一套默认组件,默认组件在DispatcherServlet.properties配置文件中。

配置文件如下:

07c6cd0b4d044fbdb6d3de9d469b8496

如 果开发者希望使用自定义类型的组件,则只需要在Spring配置文件中配置自定义的Bean即可。MVC如果发现上下文中有用户自定义的组件,就不会使用默认组件。

SpringMVC开发步骤

1.在web.xml中定义前端控制器DispatcherServlet来拦截用户请求

2.定义处理用户请求的Handle类,可以实现Controller接口或使用@Controller注解

3.配置Handle,可采用xml文件或注解的方式

@Controllerpublic class HelloController{    @RequestMapping(value="/hello")    public ModelAndView hello(){    }}

4.编写视图资源,Handle处理用户请求结束后,通常会返回一个ModelAndView对象,该对象包含返回的试图名和模型。试图名代表需要显示的物理视图资源;模型用于传输数据给视图资源。

SpringMVC执行流程

8b87caaa4ad64efc94768c40de6d7521

说明如下:

(1)用户向服务器发送请求,请求被Spring的前端控制器DispatcherServlet截获

(2)DispatcherServlet对请求URL进行解析,得到URI。然后根据URI,调用HandlerMapping获得该Handler配置的所有相关对象,包括Handler对象以及Handler对象对应的拦截器,会被封装到一个HandlerExecutionChain对象中返回

(3)DispatcherServlet根据获得的Handler,选择一个HandlerAdapter。HandlerAdapter会被用于处理多种Handler,调用Handler实际处理请求的方法

(4)提取请求中的模型数据,开始执行Handler。在填充Handler的入参过程中,根据配置spring会帮你实现消息转换、数据转换、数据格式化、数据验证

(5)Handler执行完成后,向DispatcherServlet返回一个ModelAndView对象。ModelAndView对象中包含试图名和模型

(6)根据返回的ModelAndView对象,选择一个ViewResolver返回给DispatcherServlet

(7)ViewResolver结合Model和View来渲染视图

(8)将试图渲染结果返回给客户端

SpringMVC常用注解

1.@Controller注解

@Controller用于标记一个类,使用它标记的类就是一个Controller对象,及一个控制器。Spring使用扫描机制查找应用中所有基于注解的控制器类。

@Controllerpublic class HelloController{    @RequestMapping(value="/hello")    public ModelAndView hello(){    }}

使用注解前需要如下步骤

  • 在SpringMVC配置文件的头中引入spring-context
  • 使用元素,功能是:启动包扫描功能,以便注册带有@Controller、@Service、@Repository、@Component等注解的类成为Bean。base-package指定了需要扫描的类包,类包及其递归子包中的所有类都会被扫描。配置如下:

springmvc-config.xml常用配置

6dc2162510974cf5899c76c54befcbbc

说明如下:

(1)使用指定需要扫描的包

(2)会自动注册RequestMappingHandlerMapping和Request MappingHandlerAdapter两个Bean,提供注解的必要支持

(3)是静态资源处理器,SpringMVC会默认捕获所有请求,包括静态资源请求。配置了当前元素后静态资源不会被DispatcherServlet处理

(4)视图解析器InternalResourceViewResolver来解析视图,将View呈现给用户。配置的prefix属性表示视图的前缀,suffix表示视图的后缀。

2.@RequestMapping注解

@RequestMapping注解可以用来注释一个控制器类,所有方法都将映射为相对于类级别的请求,表示该控制器处理的所有请求都被映射到value属性所指示的路径下。

d7e58dd4b50b4f7ebf436e1d1b40de75

上图代表映射到如下路径:

http://localhost:8080/user/registerhttp://localhost:8080/user/login

常用属性如下:

12485a6557bd4d8690b7c1f50be4cda1

3.请求处理方法可出现的参数类型

所有参数Spring会自动将值传给方法

(1)HttpServletRequest参数

47aa240ebcbf4603a0ff7c1d16af3de5

(2)HttpSession参数

15d056c4b0e24b1787b27875dc43f6b8

(3)HttpServletResponse

(4)InputStream

(5)OutputStream

(6)Map

(7)Model

(8)ModelMap

(9)BindingResult

(10)WebRequest

4.请求处理方法可返回的类型

  • ModelAndView
  • Model
  • Map
  • View
  • String

下面做一些详细说明。

(1)Model和ModelMap

SpringMVC在调用处理方法之前会创建一个隐含的模型对象,作为模型数据的存储容器。如果处理方法的参数为Model或ModelMap类型,则SpringMVC会将隐含模型的引用传递给这些参数。在处理方法内部,开发者可以通过这个参数对象访问模型中的所有数据,也可以向模型中添加新的数据。

09eeffc226c94e7abe16fcbce115a28f

(2)ModelAndView

控制器处理方法的返回值如果是ModelAndView,则既包含模型数据,也包含视图信息。

常用方法如下:

//添加模型数据addObject(String key, Object value);//设置视图setViewName(String name);
945827b094be48309bd14e11b6a453c0

5.页面转发

(1)转发到JSP

//默认forward跳转return "main";modelAndView.setViewName("main");//重定向页面return "redirect:/main.jsp";modelAndView.setViewName("redirect:/main.jsp");

(2)转发到其他处理方法

//forward跳转return "forward:/main";modelAndView.setViewName("forward:/main");//重定向return "redirect:/main";modelAndView.setViewName("redirect:/main");

6.@RequestParam注解

@RequestParam用于将指定的请求参数赋值给方法中的形参。属性如下:

name:指定请求参数绑定的名称value:name属性的别名required:指定参数是否必须绑定defaultValue:指定默认值
16b3b366e3854072a2f38505658be378

7.@PathVariable注解

@PathVariable可以方便的获得请求URL中的动态参数。属性如下:

ebf30da141d0401a8e7ee866e7b01cc9

举例如下:

@RequestMapping(value="/pathVariableTest/{userId}")public void pathVariableTest(@PathVariable Integer userId)

假如请求的URL为http://localhost:8080/pathVariableTest/1,则自动将URL中模板变量{userId}绑定到通过@PathVariable注解的同名参数上,即userId变量将被赋值为1。

8.@RequestHeader注解

@RequestHeader注解用于将请求头信息数据映射到功能处理方法的参数上。属性如下:

49fe8656c147458baa1eebba462fa954

举例如下:

f1fba942aecd4b3ebed85c0a97b897d6

9.@CookieValue注解

@CookieValue注解用于将请求的Cookie数据映射到功能处理方法的参数上。属性如下:

354815c36b3148dbbacaa15b6ca59679

举例如下:

f9966f26adab4a0e85aa008aeac702ee

10.@RequestAttribute注解

@RequestAttribute注解用于访问由请求处理方法、过滤器或拦截器创建的、预先存在于request作用域中的属性,将该属性转换到目标方法的参数。属性如下:

b09dc343a6cb4283818c42054c51de67

举例如下:

e03177206b42471bae095da466232444

11.@SessionAttribute注解

@SessionAttribute注解用于访问由请求处理方法、过滤器或拦截器创建的、预先存在于session作用域中的属性,将该属性转换到目标方法的参数。属性如下:

fb416a13f24f4ffd8308c1d8958abd11

举例如下:

b97608af18f345bfb7a39e01e44f9a1d

12.@ModelAttribute注解

@ModelAttribute注解用于将请求参数绑定到对象。

举例如下:

3fcd755741ac45aca21fa482d0dd154a

Form请求的参数值会自动入参到@ModelAttribute注解的对象的同名属性中

13.@RequestBody注解

@RequestBody注解用来处理content-type类型为:application/json或application/xml的情况,将请求数据绑定到方法参数上。

举例如下:

8faa8d8af11640db8abe6b2d633401a3

其中前台向处理方法传递了Json格式的数据,Json数据的key和Book属性相对应

14.@ResponseBody注解

@ResponseBody注解用于将请求处理方法返回的对象,转换为指定格式后,写入到Response对象的body中。返回的数据不是HTML页面,而是其他格式数据,如JSON、XML时使用注解。

举例如下:

6010820107a343d39b47a2181400f651

上图将List转换为Json格式输出

15.@RestController注解

@RestController注解相当于同时使用了@Controller和@ResponseBody。用于RESTFUL风格的请求处理方式。

SpringMVC异常处理

SpringMVC提供的两种异常处理方式:

  • 使用异常处理器SimpleMappingExceptionResolver,类有如下方法:
//该方法处理程序执行期间被抛出的异常,返回一个模型和视图,视图返回错误处理页面ModelAndView resolveException(HttpServletRequest request, HttpServletResponse response)

通过springmvc-config.xml配置实现

ioerrorsqlerror
  • 使用@ExceptionHandler注解实现局部异常处理
a08db3f1125544fc8ca910976ca36a58

@ExceptionHandler注解只在当前类生效

  • 使用@ControllerAdvice注解实现全局异常处理

使用扫描到@ControllerAdvice注解后,会将注解修饰的类内部使用@ExceptionHandler、@InitBinder、@ModelAttribute注解的方法应用到所有请求的异常处理上。

deddf7be6e1740498eea76705bdfaf5d

SpringMVC国际化

1.messageSource接口

SpringMVC不直接使用java.util.ResourceBundle,而是使用messageSource的Bean来配置国际化属性文件。

f061cecda006470e8e40e0a7ee2480b3

上图basenames指定了资源文件的名称

2.localeResolver接口

SpringMVC使用语言区域解析器来实现用户选择语言区域。提供了一个语言区域解析器接口LocaleResolver,实现类包括:

  • AcceptHeaderLocaleResolver
  • SessionLocaleResolver
  • CookieLocaleResolver

AcceptHeaderLocaleResolver是默认解析器,会读取浏览器accept-language标题,来确定使用哪个语言区域

3.message标签

SpringMVC显示本地化消息使用message标签,使用前需先导入taglib标签库。

message标签属性如下:

010e0b4c75794c3889e68ec9060e1579

4.AcceptHeaderLocaleResolver

实现步骤:

(1)创建资源文件

message_en_US.properties

3404fa261162422d9888a8e921e96e44

message_zh_CN.properties

e58e59512b134b5b8d05d6bb1e3f1c09

(2)在JSP中使用message标签输出国际化消息

015f516e62ae457bac9e8fc6e7d9d117

(3)在SpringMVC配置文件中加载国际化资源文件并配置

8191d8984ba140e2a619b853a3e2514e

(4)可在controller中使用国际化

RequestContext requestContext = new RequestContext(request);String username = requestContext.getMessage("username");

SpringMVC数据转换、格式化、校验原理

Spring MVC框架将ServletRequest对象及处理方法的参数对象传递给DataBinder,DataBinder调用ConversionService组件进行数据类型转换、数据格式化工作,并将ServletRequest中的消息填充到参数对象中。然后再调用Validator组件对已经绑定了请求消息数据的参数对象进行数据合法性校验,并最终生成 数据绑定结果BindingResult 对象。

aace4d018dae41e0aef9a62a63280fa5

SpringMVC文件上传

实现步骤:

(1)创建表单并设置为multipart/form-data

(2)创建controller

39df95ecce0840b5a173f7e906baa921

SpringMVC会将上传文件绑定到MultipartFile对象。MultipartFile提供了获取上传文件内容、文件名等方法。

MultipartFile常用方法如下:

byte[] getBytes():获取文件数据String getContentType():获取文件MIME类型,如image/jpegInputStream getInputStream():获取文件流String getName(): 获取表单中文件组件的名称String getOriginalFilename():获取上传文件的原名long getSize(): 获取文件的字节大小,单位为byteboolean isEmpty(): 是否有上传的文件void transferTo(File file):将上传文件保存到一个目标文件中

(3)在SpringMVC配置文件中增加文件上传功能(配置MultipartResolver)

34baf0cf84e84d14b12b49e4f4897b7c

CommonsMultipartResolver必须依赖于Apach FileUpload组件,需要引入JAR包

SpringMVC文件下载

实现步骤:

(1)在页面中加入下载超链接,链接地址指向controller方法

(2)编写controller处理方法,用于文件下载

79afa68c2a5a429cbc1dfe33510ed05c

使用Apache FileUpload组件FileUtils读取要下载的文件,并将其构建成ResponseEntity对象返回。ResponseEntity对象可以方便的定义返回的BodyBuilder、HttpHeaders、HttpStatus。

BodyBuilder对象用来构建返回的Body

HttpHeaders代表Http协议头信息

HttpStatus代表Http协议的状态

SpringMVC拦截器

Interceptor拦截器的主要作用是拦截用户的请求并进行相应的处理(比如通过拦截器来进行用户权限验证,或者用来判断用户是否已经登录等)

1.HandlerInterceptor接口

定义拦截器类需要实现HandlerInterceptor接口或继承抽象类HandlerInterceptorAdapter

接口中的方法如下:

//该方法在请求处理之前被调用,可以做前置的初始化操作或者是对当前请求的一个预处理,也可以判断来请求是否要继续进行下去。当返回值为false,表示请求结束,后续的Interceptor和Controller不会再执行;当返回值为true泽会继续执行boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler)//该方法在controller方法被执行,在视图返回渲染前被调用。可以在这个方法中对处理后的ModelAndView进行操作void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView mv)//该方法将在整个请求结束后执行,作用是进行资源清理void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception exception)

实现步骤:

(1)定义拦截器类,实现接口和接口中的方法

0a8ff0d4cb3c4f3f8199a556da47262b
e138e4c127a94878891aedee33e9fea6

(2)在配置文件中配置拦截器(springmvc-config.xml)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
SpringMVC 中,我们可以通过 ResponseBody 注解返回音频流,具体步骤如下: 1. 在 Controller 中定义一个返回类型为 ResponseEntity<byte[]> 的方法,该方法需要使用 @ResponseBody 注解标注。 2. 在方法中获取音频文件的字节数组,并将其放入 ResponseEntity 对象中返回。 3. 在 ResponseEntity 对象中设置 Content-Type、Content-Disposition 等响应头,以便浏览器正确解析音频流并进行播放。 示例代码如下: ```java @RequestMapping("/audio") @ResponseBody public ResponseEntity<byte[]> getAudio() throws IOException { // 读取音频文件字节数组 InputStream in = getClass().getResourceAsStream("/static/audio/sample.mp3"); byte[] audioBytes = IOUtils.toByteArray(in); // 设置响应头 HttpHeaders headers = new HttpHeaders(); headers.setContentType(MediaType.parseMediaType("audio/mpeg")); headers.setContentDispositionFormData("attachment", "sample.mp3"); // 返回音频流 return new ResponseEntity<>(audioBytes, headers, HttpStatus.OK); } ``` 上述代码中,我们将音频文件 sample.mp3 放在了项目的 /static/audio 目录下。在方法中,我们使用 IOUtils.toByteArray() 方法将音频文件转换为字节数组,并将其放入 ResponseEntity 对象中返回。在设置响应头时,我们使用 MediaType.parseMediaType() 方法设置 Content-Type,使用 setContentDispositionFormData() 方法设置 Content-Disposition。最后,我们通过 new ResponseEntity<>(audioBytes, headers, HttpStatus.OK) 创建 ResponseEntity 对象并返回。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值