@RequestBody与@ResponseBody

@RequestMapping
RequestMapping是一个用来处理请求地址映射的注解,可用于类或方法上.
用于类上:表示类中的所有响应请求的方法都是以该地址作为父路径.
@RequestMapping(value = "/aaa")//类级别,可以没有
public class myController {
    @RequestMapping(value = "/bbb")//方法级别,必须有
    public String getMyName() {
        return "myReturn";
    }
}
对应的action就是:<form action="aaa/bbb">
返回页面就是myReturn.jsp

@Responsebody与@RequestBody
@Responsebody表示该方法的返回结果直接写入HTTP response body中,一般在异步获取数据时使用.
在使用@RequestMapping后,返回值通常解析为跳转路径.
而使用@Responsebody后返回结果不会被解析为跳转路径,而是直接写入HTTP response body中.
比如异步获取json数据,加上@Responsebody后,会直接返回json数据.
@RequestBody将HTTP请求正文插入方法中,使用适合的HttpMessageConverter将请求体写入某个对象.
Javascript方法:
function login() {//页面异步请求
    var mydata = '{"name":"' + $('#name').val() + '","id":"'
            + $('#id').val() + '","status":"' + $('#status').val() + '"}';
    $.ajax({
        type : 'POST',
        contentType : 'application/json',
        url : "${pageContext.request.contextPath}/person/login",
        processData : false,
        dataType : 'json',
        data : mydata,
        success : function(data) {
            alert("id: " + data.id + "\nname: " + data.name + "\nstatus: "
                    + data.status);
        },
        error : function() {
            alert('出错了!');
        }
    });
};
Java方法:
@RequestMapping(value = "person/login")
    @ResponseBody
    public Person login(@RequestBody Person person) {//将请求中的mydata写入Person对象中
        return person;//不会被解析为跳转路径,而是直接写入HTTP response body中
    }

@PathVariable获取请求路径变量
Javascript中方法:
function profile() {
    var url = "${pageContext.request.contextPath}/person/profile/";
    var query = $('#id').val() + '/' + $('#name').val() + '/'
            + $('#status').val();
    url += query;
    $.get(url, function(data) {
        alert("id: " + data.id + "\nname: " + data.name + "\nstatus: "
                + data.status);
    });
}
Java中方法:
@RequestMapping(value = "person/profile/{id}/{name}/{status}")
    @ResponseBody
    public Person porfile(@PathVariable int id,@PathVariable String name,@PathVariable boolean status) {
        return new Person(id, name, status);
    }
@RequestMapping(value = "/person/profile/{id}/{name}/{status}")中的{id}/{name}/{status}与
@PathVariable int id, @PathVariable String name,@PathVariable boolean status的参数名必须一一对应,按名匹配.


MappingJacksonHttpMessageConverter 调用了 objectMapper.writeValue(OutputStream stream, Object)方法,
使用@ResponseBody注解返回的对象就传入Object参数内。
若返回的对象为已经格式化好的json串时,不使用@RequestBody注解,而应该这样处理:
1、response.setContentType("application/json; charset=UTF-8");
2、response.getWriter().print(jsonStr);
直接输出到body区,然后的视图为void。
@RequestBody@ResponseBody都是Spring框架中用于RESTful风格的接口处理中的注解,而且它们的作用是针对请求数据和响应数据的。 @RequestBody的作用是用来指定请求数据的格式,也就是告诉Spring框架如何将HTTP请求Body转化为Java对象。如果在一个Controller中使用了@RequestBody注解,那么当客户端发送请求的时候,请求Body中的数据将会被Spring框架解析并转换为对象,然后传给Controller进行处理。 @ResponseBody的作用则是将Java对象直接转化为HTTP响应Body,并且将其作为响应返回给客户端。如果在一个Controller中使用了@ResponseBody注解,那么Spring框架将会将方法的返回结果序列化成JSON或XML格式的数据,然后发送给客户端。 因此,@RequestBody@ResponseBody两者的区别如下: 1. @RequestBody注解用于请求数据的处理,@ResponseBody注解用于响应数据的处理。 2. @RequestBody注解将HTTP请求Body转化为Java对象,@ResponseBody注解将Java对象直接转化为HTTP响应Body。 3. @RequestBody注解接收请求参数时,请求参数只能是POST请求方式,@ResponseBody注解通过将Java对象序列化成JSON或XML格式的数据发送给客户端。 总之,@RequestBody注解主要用于将HTTP请求Body转化为Java对象,方便Java代码操作请求参数,而@ResponseBody注解主要用于将Java对象序列化成JSON或XML格式的数据发送给客户端,便于客户端操作响应数据。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值