IT/Spring

[Spring] Parameter Mapping 방법

Bamdule 2020. 9. 2. 12:05

Spring은 전달받은 파라미터를 매핑하는 여러가지 방법을 제공합니다.

1. @PathVariable

파라미터를 URL에 포함시켜 전달하는 방법입니다.

http://localhost/api/PathVariable/member/1
    @GetMapping("/PathVariable/{type}/{id}")
    @ResponseBody
    public String pathVariableTest(
            @PathVariable Integer id,
            @PathVariable String type
    ) {
        //type : member, id : 1
        return "success";
    }

추출할 url depth에 중괄호({})를 감싸서 매핑할 수 있습니다.
중괄호 안에 들어간 name과 @PathVariable을 선언한 변수명이 같아야합니다.
다르게 하고 싶다면 아래와 같이 작성해야합니다.

    @GetMapping("/PathVariable/{type}/{id}")
    @ResponseBody
    public String pathVariableTest(
            @PathVariable("id") Integer typeId,
            @PathVariable String type
    ) {
        //type : member, typeId : 1
        return "success";
    }

 

2. @RequestParam

key=value 형식으로 전달된 파라미터를 매핑하는 어노테이션입니다.
파라미터 전달 시 content-type은 application/x-www-form-urlencoded; charset=UTF-8;으로 해주어야합니다. 
Get 방식으로 전달 할 경우 url 맨 뒤에 ?key=value 형식으로 전달되고, Post 방식일 경우 Body를 통해 전달됩니다.

1) jquery ajax

//Jquery ajax
   $.ajax({
        url: "/api/RequestParam",
        type: "GET",
        data: {
            id: 1,
            name: "kim",
            description: "member",
            address: "seoul",
            active: true
        },
        contentType: "application/x-www-form-urlencoded; charset=UTF-8;"
    });

2) Test Controller

    @GetMapping("/RequestParam")
    @ResponseBody
    public String requestParam(
            @RequestParam(required = false, value = "id") Integer memberId,
            @RequestParam(required = false) String name,
            @RequestParam(required = false) String description,
            @RequestParam(required = false) String address,
            @RequestParam(required = false) boolean active
    ) {
        //처리..
        return "success";
    }
http://localhost:8080/api/RequestParam?id=1&name=kim&description=member&address=seoul&active=true

3) 모든 파라미터 한번에 받기

모든 파라미터를 한번에 받으려면 Map을 이용하면 됩니다.

    @GetMapping("/RequestParam")
    @ResponseBody
    public String requestParam(
            @RequestParam Map<String, Object> allParameters
    ) {
        //처리..
        return "success";
    }

 Map을 통해서 파라미터를 전달받으면 편하지만, 명확하게 어떤 파라미터를 전달받는지 모른다는 단점이 있습니다.

4) 배열 객체 넘기기

    $.ajax({
        url: "/api/RequestParam",
        type: "POST",
        data: {
            arr: [1, 2, 3]
        },
        contentType: "application/x-www-form-urlencoded; charset=UTF-8;"
    });
    @PostMapping("/RequestParam")
    @ResponseBody
    public String requestParam(
            @RequestParam(required = false, value = "arr[]") List<Integer> arr
    ) {
        return "success";
    }

5) 배열 String 넘기기

    $.ajax({
        url: "/api/RequestParam",
        type: "POST",
        data: {
            arr: "1,2,3"
        },
        contentType: "application/x-www-form-urlencoded; charset=UTF-8;"
    });
    @PostMapping("/RequestParam")
    @ResponseBody
    public String requestParam(
            // form의 input 배열을 받을 때도 아래와 같이 사용한다. ex) checkbox, multiselectbox
            @RequestParam(required = false, value = "arr") List<Integer> arr
    ) {
        return "success";
    }

3. @ModelAttribute

key=value 형식으로 전달된 파라미터를 매핑하는 어노테이션입니다.
파라미터 전달 시 content-type은 application/x-www-form-urlencoded; charset=UTF-8;으로 해주어야합니다. 
@RequestParam은 변수 한개씩 매핑하는 반면에 @ModelAttribute는 Object를 통해 한번에 받을 수 있습니다.
Object의 setter와 getter를 필수로 만들어주어야 합니다.

public class Member {

    private Integer id;
    private String name;
    private String description;
    private String address;
    private boolean active;
    private List<Integer> arr;
    
    //setter,getter 생략
    
}
    $.ajax({
        url: "/api/ModelAttribute",
        type: "GET",
        data: {
            id: 1,
            name: "kim",
            description: "super member",
            address: "seoul",
            active: true,
            arr: "1,2,3"
        ),
        contentType: "application/x-www-form-urlencoded; charset=UTF-8;"
    });
    @GetMapping("/ModelAttribute")
    @ResponseBody
    public Member ModelAtrribute(
            @ModelAttribute Member member
    ) {
        return member;
    }
localhost:8080/api/ModelAttribute?id=1&name=kim&description=member&address=seoul&active=true&arr=1%2C2%2C3

Member Object 여러개 전송하기

public class MemberArray {
    private List<Member> members;
    //getter,setter 생략
}
function modelAttribute() {
    var param = {};

    for (var index = 0; index < 5; index++) {
        param[`members[${index}].id`] = index;
        param[`members[${index}].name`] = "kim";
        param[`members[${index}].description`] = "description !";
        param[`members[${index}].address`] = "seoul";
        param[`members[${index}].active`] = true;
        param[`members[${index}].arr`] = "1,2,3,4";
    }

    $.ajax({
        url: "/api/ModelAttribute",
        type: "POST",
        data: param,
        dataType: 'json',
        contentType: "application/x-www-form-urlencoded; charset=UTF-8;"
    });
}
    @PostMapping("/ModelAttribute")
    @ResponseBody
    public Object ModelAtrributePost(
            @ModelAttribute MemberArray memberArray
    ) {
        return member;
    }

4. @RequestBody

Json이나 Xml로 전송된 파라미터를 매핑할 때 사용하는 어노테이션입니다.
content-type은 application/json; UTF-8;로 해주어야합니다.

    var json = {
        id: 1,
        name: "kim",
        description: "super member",
        address: "seoul",
        active: true,
        arr: [1, 2, 3]
    };

    $.ajax({
        url: "/api/RequestBody",
        type: "POST",
        data: JSON.stringify(json),
        dataType: 'json',
        contentType: "application/json; UTF-8;"
    });

JSON.stringify() 를 이용해 객체를 JsonString으로 변환합니다.

    @PostMapping("/RequestBody")
    @ResponseBody
    public Member RequestBody(
            @RequestBody Member member
    ) {
        return member;
    }
{"id":1,"name":"kim","description":"super member","address":"seoul","active":true,"arr":[1,2,3]}

Member Json Object 여러개 전송하기

    var json = {
        id: 1,
        name: "kim",
        description: "super member",
        address: "seoul",
        active: true,
        arr: [1, 2, 3]
    };
    
    var jsons = [json, json, json];

    $.ajax({
        url: "/api/RequestBodyList",
        type: "POST",
        data: JSON.stringify(jsons),
        dataType: 'json',
        contentType: "application/json; UTF-8;"
    });
    @PostMapping("/RequestBodyList")
    @ResponseBody
    public Object RequestBodyListPost(
            @RequestBody List<Member> members
    ) {
        return members;
    }
[{"id":1,"name":"kim","description":"super member","address":"seoul","active":true,"arr":[1,2,3]},{"id":1,"name":"kim","description":"super member","address":"seoul","active":true,"arr":[1,2,3]},
{"id":1,"name":"kim","description":"super member","address":"seoul","active":true,"arr":[1,2,3]}]