#HttpMessageConverter报文转换器
HttpMessageConverter提供了两个注解和两个类型:@RequestBody,@ResponseBody,RequestEntity, ResponseEntity
1、@RequestBody
@RequestBody可以获取请求体,需要在控制器方法设置一个形参,使用@RequestBody进行标识,当前请求的请求体就会为当前注解所标识的形参赋值
@RequestMapping("/testRequestBody")
public String testRequestBody(@RequestBody String requestBody){
System.out.println("requestBody:"+requestBody);
return "success";}
输出结果:
requestBody:username=admin&password=123456
2、RequestEntity
RequestEntity封装请求报文的一种类型,需要在控制器方法的形参中设置该类型的形参,当前请求的请求报文就会赋值给该形参,可以通过getHeaders()获取请求头信息,通过getBody()获取请求体信息
@RequestMapping("/testRequestEntity")
public String testRequestEntity(RequestEntity<String> requestEntity){
System.out.println("requestHeader:"+requestEntity.getHeaders()); System.out.println("requestBody:"+requestEntity.getBody()); return "success";}
3、@ResponseBody
@ResponseBody用于标识一个控制器方法,可以将该方法的返回值直接作为响应报文的响应体响应到浏览器
@RequestMapping("/testResponseBody")
@ResponseBody //加上这个下边return就不再是视图名称了而是当前响应的响应体
public String testResponseBody(){
return "浏览器显示的内容,这个比较特殊会在浏览器显示";}
*mvc@ResponseBody 处理json
导jackson依赖
开启mvc注解驱动
方法上加@ResponseBody
将java对象作为控制器方法返回就会自动转换成json字符串
**@RestControllerRestController=@ResponseBody+@Controller
4、ResponseEntity
ResponseEntity用于控制器方法的返回值类型,该控制器方法的返回值就是响应到浏览器的响应报文
使用ResponseEntity实现
下载文件的功能
@RequestMapping("/testDown")
public ResponseEntity<byte[]> testResponseEntity(HttpSession session) throws IOException {
//获取ServletContext对象
ServletContext servletContext = session.getServletContext(); //获取服务器中文件的真实路径
String realPath = servletContext.getRealPath("/static/img/1.jpg"); //创建输入流
InputStream is = new FileInputStream(realPath); //创建字节数组
byte[] bytes = new byte[is.available()]; //将流读到字节数组中
is.read(bytes); //创建HttpHeaders对象设置响应头信息
MultiValueMap<String, String> headers = new HttpHeaders(); //设置要下载方式以及下载文件的名字
headers.add("Content-Disposition", "attachment;filename=1.jpg"); //设置响应状态码
HttpStatus statusCode = HttpStatus.OK; //创建ResponseEntity对象
ResponseEntity<byte[]> responseEntity = new ResponseEntity<>(bytes, headers, statusCode); //关闭输入流
is.close(); return responseEntity;}
文件上传
添加依赖commons-fileupload
在SpringMVC的配置文件中添加配置:
<!--必须通过文件解析器的解析才能将文件转换为MultipartFile对象-->
<bean id="multipartResolver" class="org.springframework.web.multipart.commons.CommonsMultipartResolver"></bean>
控制器接收:
@RequestMapping("/testUp")
public String testUp(MultipartFile photo, HttpSession session) throws IOException {
//获取上传的文件的文件名
String fileName = photo.getOriginalFilename(); //处理文件重名问题
String hzName = fileName.substring(fileName.lastIndexOf(".")); fileName = UUID.randomUUID().toString() + hzName; //获取服务器中photo目录的路径
ServletContext servletContext = session.getServletContext(); String photoPath = servletContext.getRealPath("photo"); File file = new File(photoPath); if(!file.exists()){ file.mkdir(); } String finalPath = photoPath + File.separator + fileName; //实现上传功能
photo.transferTo(new File(finalPath)); return "success";}