目录
前言
数据准备
链接: https://pan.baidu.com/s/17ztrNlfgu3NP_u2-5d9g3w 提取码: v05b
一、SpringMVC的数据响应
1.1 SpringMVC的数据响应方式
1.1.1页面跳转
直接返回字符串
- 在文件中新建一个文件夹,将success.jsp 页面放进去
2.在sring-mvc.xml文件中添加
<!-- 配置资源视图解析器--> <bean id="viewResolve" class="org.springframework.web.servlet.view.InternalResourceViewResolver"> <property name="prefix" value="/jsp/"/> <property name="suffix" value=".jsp"/> </bean>
此处添加的配置含义是:
当页面放在jsp文件夹后,tomcat服务器中资源success.jsp页面与默认的index.jsp不在同一个目录下,因此在访问的真实路径中需要添加为/jsp/success.jsp
但是这太麻烦了,而在。。。(我也不记得了)的父类源码中提供了一种在xml中配置真实访问路径的方法,也就是上面这个配置文件,因此,在UserController文件中,只需要配置访问的路径名字就可以,不需要再写success.jsp
1.1.2通过ModelAndView对象返回
success.jsp
/user/quick2
使用注入实现 :
1.2 回写数据
1.2.1直接返回字符串
Web基础阶段,客户端访问服务器端,如果想直接回写字符串作为响应体返回的话,只需要使用 response.getWriter().print(“hello world”) 即可,Controller中想直接回写字符串,方法如下:
1 通过SpringMVC框架注入的response对象,使用response.getWriter().print(“hello world”) 回写数 据,此时不需要视图跳转,业务方法返回值为void。
@Controller
@RequestMapping("/user")
public class UserController {
Date now = new Date();
String strDateFormat = "yyyy-MM-dd HH:mm:ss";
LocalDateTime localDateTime = now.toInstant().atZone(ZoneId.systemDefault()).toLocalDateTime();
String result = localDateTime.format(DateTimeFormatter.ofPattern(strDateFormat));
@RequestMapping(value="/quick6")
public void invoke6(HttpServletResponse response) throws IOException {
response.setCharacterEncoding("GBK");
response.getWriter().write("现在时间是:"+result);
}
此处异常先抛出,后面会详细更更新
但此处仍不满足需求,解耦合,所以
2 将需要回写的字符串直接返回,但此时需要通过@ResponseBody注解告知SpringMVC框架,方法 返回的字符串不是跳转是直接在http响应体中返回。
@Controller
@RequestMapping("/user")
public class UserController {
Date now = new Date();
String strDateFormat = "yyyy-MM-dd HH:mm:ss";
LocalDateTime localDateTime = now.toInstant().atZone(ZoneId.systemDefault()).toLocalDateTime();
String result = localDateTime.format(DateTimeFormatter.ofPattern(strDateFormat));
@ResponseBody //此处不进行页面跳转,进行回写数据
@RequestMapping(value="/quick7")
public String invoke7(){
return result;
}
返回json格式
- pom.xml文件导入json包
<dependency> <groupId>com.fasterxml.jackson.core</groupId> <artifactId>jackson-core</artifactId> <version>2.13.1</version> </dependency> <dependency> <groupId>com.fasterxml.jackson.core</groupId> <artifactId>jackson-databind</artifactId> <version>2.13.1</version> </dependency> <dependency> <groupId>com.fasterxml.jackson.core</groupId> <artifactId>jackson-annotations</artifactId> <version>2.13.1</version> </dependency>
- 模拟加入一个对象,在当前文件下加入,目录domain user
@ResponseBody //此处不进行页面跳转,进行回写数据 @RequestMapping(value="/quick8") public String invoke8() throws JsonProcessingException, UnsupportedEncodingException { user user =new user(); user.setName("lisi"); user.setAge(25); ObjectMapper objectMapper = new ObjectMapper(); String string = objectMapper.writeValueAsString(user); return string; }
1.2.2返回对象或集合
通过SpringMVC对对象或集合进行json字符串的转换并回写,为处理器适配器配置消息转换参数, 指定使用jackson进行对象或集合的转换,因此需要在spring-mvc.xml中进行如下配置:
<!--配置处理器映射器--> <bean class="org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter"> <property name="messageConverters"> <list> <bean class="org.springframework.http.converter.json.MappingJackson2HttpMessageConverter"> </bean> </list> </property> </bean>
有个简便的方法
在方法上添加@ResponseBody就可以返回json格式的字符串,但是这样配置比较麻烦,配置的代码比较多, 因此,我们可以使用mvc的注解驱动代替上述配置。
<mvc:annotation-driven/>
头部注意引入:
xmlns:mvc="http://www.springframework.org/schema/mvc" http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc.xsd
在 SpringMVC 的各个组件中,处理器映射器、处理器适配器、视图解析器称为 SpringMVC 的三大组件。 使用<mvc:annotation-driven>自动加载 RequestMappingHandlerMapping(处理映射器)和 RequestMappingHandlerAdapter( 处 理 适 配 器 ),可用在Spring-xml.xml配置文件中使用 <mvc:annotation-driven>替代注解处理器和适配器的配置。 同时使用<mvc:annotation-driven>默认底层就会集成jackson进行对象或集合的json格式字符串的转换。
二、SpringMVC获得请求数据
2.1 获得请求参数
客户端请求参数的格式是:name=value&name=value... ...
基本类型参数
POJO类型参数 类似于javabean
数组类型参数
集合类型参数
2.2 获得基本类型参数
Controller中的业务方法的参数名称要与请求参数的name一致,参数值会自动映射匹配。
例如:
链接:http://localhost:8080/user/quick9?username=zhangsan&age=18
Controller:
@ResponseBody //此处不进行页面跳转,进行回写数据
@RequestMapping(value="/quick9")
public void invoke9(String username,String age){
System.out.println(username);
System.out.println(age);
}
2.3 获得POJO类型参数
链接:http://localhost:8080/user/quick9/name=zhangsan&age=18
@ResponseBody //此处不进行页面跳转,进行回写数据
@RequestMapping(value="/quick10")
public void invoke10(user user){
System.out.println(user.getName());
System.out.println(user.getAge());
}
2.4 获得数组类型参数
@ResponseBody //此处不进行页面跳转,进行回写数据
@RequestMapping(value="/quick11")
public void invoke11(String[] strs){
System.out.println(Arrays.asList(strs));
}
Arrays.asList(strs) 将数组转换为list输出时可以看到结果
2.5 获得集合类型参数
获得集合参数时,要将集合参数包装到一个POJO中才可以。
- 首先创在一个集合:
- 集合中封装user对象
添加一个前端页面,提交数据,因为存入list集合中时可以存在多个user对象,因此此处的写法使用角标的方式判断是第几个user对象
此处引、入集合后直接打印
链接:/jsp/form.jsp
结果:
当使用ajax提交时,可以指定contentType为json形式,那么在方法参数位置使用@RequestBody可以 直接接收集合数据而无需使用POJO进行包装。
此处解释ajax
异步和同步:客户端和服务器端相互通信的基础上
* 客户端必须等待服务器端的响应。在等待的期间客户端不能做其他操作。
* 客户端不需要等待服务器端的响应。在服务器处理请求的过程中,客户端可以进行其他的操作。Ajax 是一种在无需重新加载整个网页的情况下,能够更新部分网页的技术。 [1]
通过在后台与服务器进行少量数据交换,Ajax 可以使网页实现异步更新。这意味着可以在不重新加载整个网页的情况下,对网页的某部分进行更新。
传统的网页(不使用 Ajax)如果需要更新内容,必须重载整个网页页面。提升用户的体验
创建一个新的页面
在 UserController中添加一个方法:
此时运行时会发生报错,原因是找不到js的引入文件,报错如下:
因此,需要在,spring-mvc.xml文件中添加一行代码:
原因是SpringMVC的前端控制器 DispatcherServlet的url-pattern配置的是/,代表对所有的资源都进行过滤操作,我们可以通过以下两种 方式指定放行静态资源:
• 在spring-mvc.xml配置文件中指定放行的资源
<mvc:resources mapping="/js/**" location="/js/"/>
• 使用<mvc:default-servlet-handler/>标签
当mvc找不到映射方法时,原来的操作是停止,加上这句话的意思是如果映射不到则交由tomcat处理
此时运行得到的结果是:
如果此时您的代码还是报错找不到jquery.js文件,但是代码逻辑没有问题(上面的代码带有一个bug当做小练习),很有可能是版本导致的问题
2.6 请求数据乱码问题
当post请求时,数据会出现乱码,可以设置一个过滤器来进行编码的过滤。
在web.xml文件中添加;
<!-- 配置编码--> <filter> <filter-name>CharacterEncoding</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>CharacterEncoding</filter-name> <url-pattern>/*</url-pattern> </filter-mapping>
2.7 参数绑定注解@requestParam
注解@RequestParam还有如下参数可以使用:
value:与请求参数名称 :解决请求参数与映射参数不一致
required:此在指定的请求参数是否必须包括,默认是true,提交时如果没有此参数则报错
defaultValue:当没有指定请求参数时,则使用指定的默认值赋值
@RequestMapping("/quick14")
@ResponseBody
public void quickMethod14(@RequestParam(value="name",required = false,defaultValue = "hahha") String username) throws IOException {
System.out.println(username); }
2.8 获得Restful风格的参数
Restful是一种软件架构风格、设计风格,而不是标准,只是提供了一组设计原则和约束条件。主要用于客户端和服务 器交互类的软件,基于这个风格设计的软件可以更简洁,更有层次,更易于实现缓存机制等。
Restful风格的请求是使用“url+请求方式”表示一次请求目的的,HTTP 协议里面四个表示操作方式的动词如下: GET:用于获取资源
POST:用于新建资源
PUT:用于更新资源
DELETE:用于删除资源
例如:
/user/1 GET: 得到id=1的 user
/user/1 DELETE: 删除 id = 1 的 user
/user/1 PUT: 更新id=1的user
/user POST: 新增 user
链接:http://localhost:8080/user/quick19/zhangsan
2.9 自定义类型转换器
• SpringMVC 默认已经提供了一些常用的类型转换器,例如客户端提交的字符串转换成int型进行参数设置。
• 但是不是所有的数据类型都提供了转换器,没有提供的就需要自定义转换器,例如:日期类型的数据就需要自定义转换器。
自定义类型转换器的开发步骤:
1 定义转换器类实现Converter接口
2 在配置文件中声明转换器
3 在<annotation-driven>中引用转换器
public class DateConverter implements Converter<String, Date> {
@Override
public Date convert(String s) {
SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd");
Date date = null;
try {
date = format.parse(s);
} catch (ParseException e) {
e.printStackTrace();
}
return date;
}
}
spring-mvc.xml
<mvc:annotation-driven conversion-service="converterService"/> <!-- <mvc:default-servlet-handler/>--> <bean id="converterService" class="org.springframework.context.support.ConversionServiceFactoryBean"> <property name="converters"> <list> <bean class="com.student.test.Converter.DateConverter"/> </list> </property> </bean>
在配置文件中添加:
<mvc:annotation-driven conversion-service="converterService"/>
测试链接:http://localhost:8080/user/quick14?date=2012-12-31
2.10 获得Servlet相关API
SpringMVC支持使用原始ServletAPI对象作为控制器方法的参数进行注入,常用的对象如下:
HttpServletRequest
HttpServletResponse
HttpSession
前面有哦
2.11 获得请求头
1. 使用@RequestHeader可以获得请求头信息,相当于web阶段学习的request.getHeader(name) @RequestHeader注解的属性如下:
value:请求头的名称
required:是否必须携带此请求头
2. @CookieValue
使用@CookieValue可以获得指定Cookie的值 @CookieValue注解的属性如下:
value:指定cookie的名称
required:是否必须携带此cookie
2.12 文件上传
1. 文件上传客户端三要素
表单项type=“file”
表单的提交方式是post
表单的enctype属性是多部分表单形式,及enctype=“multipart/form-data”
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
<title>Title</title>
</head>
<body>
<form action="${pageContext.request.contentType}/user/quick19" method="post" enctype="multipart/form-data">
名称<input name="name" type="text">
文件<input name="uploadFile" type="file">
</form>
</body>
</html>
2.13 单文件上传步骤
1 导入fileupload和io坐标
<dependency> <groupId>commons-fileupload</groupId> <artifactId>commons-fileupload</artifactId> <version>1.2.2</version> </dependency> <dependency> <groupId>commons-io</groupId> <artifactId>commons-io</artifactId> <version>2.4</version> </dependency>
2 配置文件上传解析器
spring-mvc.xml
<bean id="multipartResolver" class="org.springframework.web.multipart.commons.CommonsMultipartResolver"> <!--上传文件总大小--> <property name="maxUploadSize" value="5242800"/> <!--上传单个文件的大小--> <property name="maxUploadSizePerFile" value="5242800"/> <!--上传文件的编码类型--> <property name="defaultEncoding" value="UTF-8"/> </bean>
3 编写文件上传代码
@ResponseBody
@RequestMapping(value="/quick19")
public void invoke19(String name, MultipartFile uploadFile){
System.out.println(name);
System.out.println(uploadFile);
}
//获得文件名称
String originalFilename = uploadFile.getOriginalFilename(); //保存文件
uploadFile.transferTo(new File("C:\\upload\\"+originalFilename));
4.前端
2.15 多文件上传实现
多文件上传,只需要将页面修改为多个文件上传项,将方法参数MultipartFile类型修改为MultipartFile[]即可
@ResponseBody
@RequestMapping(value="/quick19")
public void invoke19(String name, MultipartFile uploadFile,MultipartFile uploadFile1,MultipartFile uploadFile2){
System.out.println(name);
System.out.println(uploadFile);
}
如果获取数组
看到这里了,点个赞呗~~~~