好记性-烂笔头:controller-接收参数方式及注意事项

长时间未使用的传参方式很容易遗忘 或 记忆混乱,虽然都很简单 但往往都是一些小细节打败了你。

小编决定要把他们记录下来。

1):@RequestBody 接收参数 及 注意事项

注意事项:

@RequestBody:后台接收只能声明一个、且只能接收 json

@RequestBody:不能和 form/data 共存

@RequestBody:必须是:contentType : "application/json;charset=utf-8" 注意:"application/json charset=utf-8" JSON不能正常解析

案例:ajxa 请求

po:

public class RequestBodyPo implements Serializable {

    private Integer id;
    private String name;
    private List<RequestBodyPo> requestBodyPoList;
    private List<RequestBodyPo> BodyPos;

    ... get set 省略...
    
}

请求:

$("#canshu").click(function () {

            var _json = {
                id: "123456",
                name:"asdasdas"
            };
            // 注意观察 requestBodyPoList & BodyPos 命名规范  后台接收数据的时候你会看到效果
            _json.requestBodyPoList = [];
            _json.BodyPos=[];

            var _01 = {id: "1", name: "_01"};
            var _02 = {id: "2", name: "_02"};

            _json.requestBodyPoList.push(_01);
            _json.requestBodyPoList.push(_02);

            _json.BodyPos.push(_01);
            _json.BodyPos.push(_02);

            $.ajax({
                type: "post",
                url: "/requestBody",
                dataType: "json",
                contentType: "application/json",
                data: JSON.stringify(_json),
                success: function (data) {
                    console.log(data);
                },
                error: function (jqXHR) {
                    alert("发生错误:" + jqXHR.status);
                }
            });
        });

controller 接收:

2):controller String[] 数组、List<String> 集合 接收参数 及 注意事项

注意事项:

@RequestParam:接收单个字段 而非对象实体

@RequestParam:使用数组接收可以使用 此注解标识  || @RequestBody 注解,区别前者可以定义多个、后者只能定义一个,并且两者的请求格式不一样

案例:ajxa 请求

var _json = ["1","2","3"];

$.ajax({
    type: "post",
    url: "/array",
    dataType: "json",
    contentType:"application/x-www-form-urlencoded",//默认值
    data: {
        strings:_json
    },
    success: function (data) {
        console.log(data);
    },
    error: function (jqXHR) {
        alert("发生错误:" + jqXHR.status);
    }
});

controller 接收:

上述演示的是 @RequestParam 接收数组、要是 list 直接换成 @RequestParam(value = "lists[]") List<String> lists 即可

如果使用:@RequestBody 改成 @RequestBody List<String> lists  再次提醒:使用此注解一定注意请求格式 及 contentType 类型

3):controller 接收 List<Map<String,Object>>集合参数  及 注意事项

注意事项:

使用 @RequestBody 方式接收

案例:ajxa 请求

var _json = [];

var _01 = {
    id: 123,
    name: "小明",
    list: [{
        id: 456,
        name: "翠花"
    }]
};
_json.push(_01);


$.ajax({
    type: "post",
    url: "/listMap",
    dataType: "json",
    contentType: "application/json;charset=utf-8",//默认值  application/x-www-form-urlencoded
    data: JSON.stringify(_json),
    success: function (data) {
        console.log(data);
    },
    error: function (jqXHR) {
        alert("发生错误:" + jqXHR.status);
    }
});

controller 接收:

 

4):Request 里如何获取 @RequestBody 对应的参数 ?

@RequestBody 用于接收http请求的请求体(request body),在 HttpServletRequest 里是以流的方式传输的。

例如:ajax 发送 POST    "Content-Type":"application/json"

在Controller里(只要能拿到HttpServletRequest的地方就可以),我用fastjson去接收并且转换成java bean,代码如下:

@RequestMapping("/param")
@ResponseBody
public Article param(HttpServletRequest request) throws IOException {
    ServletInputStream inputStream = request.getInputStream();
    Article article = JSONObject.parseObject(inputStream, Charset.forName("UTF-8"), Article.class);
    return article;
}

 

其他补充要点:

@RequestParam:还可以设置 默认参数 和 可选参数  (  @RequestParam(value = "str",defaultValue = "123",required = false) String str  )

controller:还可以接收:

对象实体、List<实体> 等   注意请求格式 contentType

posted @ 2020-01-10 14:04  coding++  阅读(1705)  评论(0编辑  收藏  举报