1 概述
SpringMVC 是一种基于Java的实现MVC设计模型的请求驱动类型的轻量级Web框架
1.1 开发步骤
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-web</artifactId>
<version>5.1.9.RELEASE</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-webmvc</artifactId>
<version>5.1.9.RELEASE</version>
</dependency>
<dependency>
<groupId>javax.servlet</groupId>
<artifactId>servlet-api</artifactId>
<version>2.5</version>
</dependency>
<dependency>
<groupId>javax.servlet.jsp</groupId>
<artifactId>jsp-api</artifactId>
<version>2.2</version>
</dependency>
<dependency>
<groupId>javax.servlet</groupId>
<artifactId>jstl</artifactId>
<version>1.2</version>
</dependency>
<servlet>
<servlet-name>DispatcherServlet</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<init-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:spring-mvc.xml</param-value>
</init-param>
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>DispatcherServlet</servlet-name>
<url-pattern>/</url-pattern>
</servlet-mapping>
4 将Controller使用注解配置到Spring容器中(@Controller) 5 配置spring-mvc.xml文件(配置组件扫描)
6 客户端发起请求测试
2 组件解析
2.1 SpringMVC执行流程
2.2 注解解析
@RequestMapping
用于建立请求URL和处理请求方法之间的对应关系。做虚拟地址映射
位置:
1 类上,请求URL的第一级访问目录,默认应用的根目录
2 方法上,请求URL的第二级访问目录,与类上使用的@RequestMapping标注的一级目录一起组成访问虚拟路径
1 value:指定请求URL,和path属性作用一样
2 method:指定请求方式
3 params:指定限制请求参数的条件,支持简单表达式。要求请求参数的key和value必须同配置一样
2.3 组件扫描
进行SpringMVC操作时,需将Controller存储到Spring容器中,如果使用@Controller注解标注,则需要使用<context:component-scan base-package=“wsw.Controller”> 包含两个内容:
1 include-filter: expression=组件全包名,表示只扫该组件
2 exclude-filter: 表示扫描除该组件外的其它组件
2.4 XML配置解析(资源解析器)
redirect:重定向前缀,会改变地址 forward:转发前缀,不会改变地址
先获取配置的前缀,即jsp文件下的 再获得 视图名称 最后获取配置后缀 .jsp
3 数据响应
3.1 SpringMVC数据响应
页面跳转
·直接返回字符串
此方式将返回字符串与视图解析器的前后缀拼接后跳转
·通过ModelAndView对象返回
ModelAndView对象 方式一: 前端页面通过el表达式获取添加的object
方式二
方式三
回写数据
·直接返回字符串
·返回对象或集合
直接返回字符串 方式一 注入response对象,使用response.getWriter().print(“hello world”)回写数据,此时不需要视图跳转,返回值为void 方式二 若将回写字符串直接返回,通过@ResponseBody注解,则方法返回的字符串是直接在http响应体中返回
方式三 返回json字符串 先在pom.xml里导包
再使用ObjectMapper转成json字符串形式
返回对象或集合
先在spring-mvc.xml里配置 处理器映射器 在Controller里返回一个对象 或 集合,SpringMVC会自动转换成json字符串。 @ResponseBody仍需要加上
!!!!!!!!!!!!!!!!! 通过mvc的注解驱动可代替上述配置
<mvc:annotation-driven/>
spring-mvc中,先添加beans配置,再添加上述代码
3.2 请求
获得请求参数
类型
1 基本类型参数
2 POJO类型参数
3 数组类型参数
4 集合类型参数
1 获得基本类型参数 Controller中的业务方法参数名称要与请求参数的name一致,参数值会自动映射匹配
2 获得POJO类型参数 Controller中 业务方法的POJO参数的属性名与请求参数的name一致,参数值会自动映射匹配
对象属性包含get、set方法后,直接在Controller里接收对象参数即可
3 获得数组类型参数 业务方法数组名称 与 请求参数name一致,会自动映射匹配
4 获得集合类型参数 新创建个 集合类
Controller业务方法
通过表单提交模仿
使用ajax提交时,可指定contentType为json形式,则方法参数位置可使用@RequestBody直接接收集合数据,无需使用POJO包装
前端页面: controller的业务方法
注意!!!!!! 在spring-mvc.xml文件中配置 开放资源的访问权限
或配置下面的代码
<mvc:default-servlet-handler/>
5 配置全局过滤filter 在web.xml里,可一次性解决所有中文传参乱码问题
<!--配置全局过滤的filter-->
<filter>
<filter-name>CharacterEncodingFilter</filter-name>
<filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class>
<init-param>
<param-name>encoding</param-name>
<param-value>UTF-8</param-value>
</init-param>
</filter>
<filter-mapping>
<filter-name>CharacterEncodingFilter</filter-name>
<url-pattern>/*</url-pattern><!--对所有资源都进行-->
</filter-mapping>
6 参数绑定注解@RequestParam @RequestParam注解 显示绑定(当请求参数名称与Controller业务方法参数名称不一致时)
1 value:请求参数名称
2 required:指定的请求参数是否必须包括,默认为true,提交时如果无此参数则报错
3 defaultValue:无指定请求参数时,则使用指定的默认值赋值
请求链接name字段可带 可不带
7 获得Restful风格的参数 一种软件设计风格、架构风格。主要用于客户端、服务器交互类的软件。 风格:
url+请求方式
GET:获取资源
POST:新建资源
PUT:更新资源
DELETE:删除资源
通过占位符进行参数绑定,使用@PathVariable注解进行占位符匹配获取
http://localhost:8080/userService/save15/abcaaaaaa
8 自定义类型转换器 步骤:
1 定义转换器类 实现Converter接口
2 在配置文件声明转换器
3 在<annotation-driven>中引用转换器
Converter类 spring-mvc.xml
9 获得Servlet相关API
常用对象:
HttpServletRequest
HttpServletResponse
HttpSession
10 获取请求头
1 @RequestHeader
value:请求头的名称
required:是否必须携带此请求头
2 @CookieValue
value:指定cookie的名称
required:是否必须携带此cookie
文件上传
文件上传客户端三要素: 1 表单项type=“file” 2 表单的提交方式为post 3 表单的enctype属性是多部分表单形式(enctype=“multipart/form-data”) 单文件上传步骤:
1 导入fileupload和io坐标
2 配置文件上传解析器
3 编写文件上传代码
fileupload、io坐标 配置文件上传解析器
其中,id唯一,必须为multipartResolver
4 拦截器与异常处理
4.1 拦截器
作用:类似Servlet开发中的过滤器Filter,用于对处理器进行预处理和后处理。
自定义拦截器步骤:
1 创建拦截器类实现HandlerInterceptor接口
2 配置拦截器
3 测试拦截器的拦截效果
1实现HandlerInterceptor接口 2 配置拦截器
多个拦截器的执行顺序根据spring-mvc.xml里的配置顺序 MyInteceptor比MyInteceptor1配置在前,先执行MyInteceptor
prehandle起到决定性作用,只有prehandle执行之后,后面的方法才可执行
4.2 异常处理
异常包括:
1 预期异常
2 运行时异常RuntimeException
异常处理的两种方式: 1、SpringMVC提供的简单异常处理器SimpleMappingExceptionResolver
2、Spring的异常处理接口HandlerExceptionResolver自定义自己的异常处理器
步骤:
1、创建异常处理器类实现HandlerExceptionResolver
2、配置异常处理器
3、编写异常页面
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/2628.html