10. SpringMVC-HttpMessageConverter

一、报文信息转换器

HttpMessageConverter,报文信息转换器,将请求报文转换为Java对象,或将Java对象转换为响应报文HttpMessageConverter提供了两个注解和两个类型:@RequestBody,@ResponseBody,RequestEntity,ResponseEntity

1. @RequestBody

  1. @RequestBody可以获取请求体,需要在控制器方法设置一个形参,使用@RequestBody进行标识,当前请求的请求体就会为当前注解所标识的形参赋值
  2. 设置请求的form表单
<form th:action="@{/testRequestBody}" method="post">
    用户名:<input type="text" name="username"><br>
    密码:<input type="password" name="password"><br>
    <input type="submit">
</form>
  1. 设置控制方法,获取请求体
@RequestMapping("/testRequestBody")
public String testRequestBody(@RequestBody String requestBody){
    System.out.println("requestBody:"+requestBody);
    return "success";
}

2. RequestEntity

  1. RequestEntity封装请求报文的一种类型,需要在控制器方法的形参中设置该类型的形参,当前请求的请求报文就会赋值给该形参,可以通过getHeaders()获取请求头信息,通过getBody()获取请求体信息
  2. form表单
<form th:action="@{/testRequestEntity}" method="post">
    <input type="text" name="username"><br>
    <input type="text" name="password"><br>
    <input type="submit" value="测试RequestEntity">
</form>
  1. 方法
	@RequestMapping("/testRequestEntity")
    public String testRequestEntity(RequestEntity<String> requestEntity){
        //当前RequestEntity表示整个请求报文的信息
        System.out.println("请求头:" + requestEntity.getHeaders());
        System.out.println("请求体:" + requestEntity.getBody());
        return "success";
    }

二、响应浏览器数据

1. HttpServletResponse

  1. 方法
	@RequestMapping("/testResponse")
    public String testResponse(HttpServletResponse response) throws IOException {
        response.getWriter().println("hello ,response");
        return null;
    }
  1. 超链接
<a th:href="@{/testResponse}">通过servletAPI的response对象响应浏览器数据</a><br>

2. @ResponseBody

  1. @ResponseBody用于标识一个控制器方法,可以将该方法的返回值直接作为响应报文的响应体响应到浏览器
  2. 方法
	@RequestMapping("/testResponseBody")
    @ResponseBody
    public String testResponseBody(){
        return "success";
    }
  1. 超链接
<a th:href="@{/testResponseBody}">通过@ResponseBody响应浏览器数据</a><br>

三、SpringMVC处理json

1. 通过@ResponseBody响应浏览器User对象

  1. 创建实体类,添加对应的set、get和构造方法
public class User {
    private Integer id;
    private String username;
    private String password;
    private Integer age;
    private String sex;
}
  1. 方法
	@RequestMapping("/testResponseUser")
    @ResponseBody
    public User testResponseUser(){
        return new User(1001,"zs","123",23,"男");
    }
  1. 超链接
<a th:href="@{/testResponseUser}">通过@ResponseBody响应浏览器User对象</a><br>

2. @ResponseBody处理json的步骤

  1. 在pom.xml中引入依赖
<dependency>
    <groupId>com.fasterxml.jackson.core</groupId>
    <artifactId>jackson-databind</artifactId>
    <version>2.12.1</version>
</dependency>
  1. 在SpringMVC的核心配置文件中开启mvc的注解驱动,此时在HandlerAdaptor中会自动装配一个消息转换器:MappingJackson2HttpMessageConverter,可以将响应到浏览器的Java对象转换为Json格式的字符串
<mvc:annotation-driven />
  1. 在处理器方法上使用@ResponseBody注解进行标识
  2. 将Java对象直接作为控制器方法的返回值返回,就会自动转换为Json格式的字符串

在这里插入图片描述

四、SpringMVC处理ajax

  1. 请求超链接
<div id="add">
    <a th:href="@{/testAxios}" @click="testAxios">SpringMVC处理ajax</a>
</div>
  1. 引入vue.js和axios.min.js
<script th:src="@{/static/js/vue.js}"></script>
<script th:src="@{/static/js/axios.min.js}"></script>
  1. 处理超链接的点击事件
<script>
    new Vue({
        el:"#add",
        methods:{
            testAxios:function (event){
                axios({
                    method:"post",
                    url:event.target.href,
                    params:{
                        username:"zss",
                        password:"123"
                    }
                }).then(function (response){
                    alert(response.data);
                });
                event.preventDefault();
            }
        }
    });
</script>
  1. 控制器方法
	@RequestMapping("/testAxios")
    @ResponseBody
    public String testAxios(String username,String password){
        System.out.println("username: " + username + ",password: " + password);
        return "hello, axios";
    }

五、@RestController注解

  1. @RestController注解是springMVC提供的一个复合注解,标识在控制器的类上,就相当于为类添加了@Controller注解,并且为其中的每个方法添加了@ResponseBody注解
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

CAFEBABE 34

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值