스프링 입문(7. API)
1. API
- demo/src/main/java/hello/demo/controller/HelloController.java
- ResponseBody 에노테이션 사용
01. @ResponseBody 문자 반환
package hello.demo.controller;
import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.ResponseBody;
@Controller
public class HelloController {
// API 방식
@GetMapping("hello-string")
// ResponseBody : http에서 head부분과 body부분이 있는데, 그 body부분에 데이터를 직접 넣어 주겠다!
// view가 없이 그대로 내려간다
@ResponseBody
public String helloString(@RequestParam("name") String name){
return "hello "+name;
}
static class Hello {
private String name;
// getter, setter, property 접근 방식
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
}
}
- @ResponseBody를 사용하면 뷰 리졸버(ViewResolver)를 사용하지 않음
- 디신에 HTTP의 BODY에 문자 내용을 직접 반환(HTML BODY TAG를 말하는 것이 아님)
02. @ResponseBody 객체 반환
package hello.demo.controller;
import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.ResponseBody;
@Controller
public class HelloController {
// API 방식
// JSON 방식으로 객체 전달(key, value)
// xml은 무겁고 열고 닫고 태그를 두번써야 하는거에 비해 JSON은 객체 형식으로 심플하다
// 객체로 return하게 되면 ViewEesolve 대신에 HttpMessageConverter가 동작하면서 JsonConverter랑 StringConverter 중 JSON으로 자동 변환해서 전송한다
// 기본문자처리 : StringHttpMessageConverter
// 기본 객체처리 : MappingJackson2HttpMessageConverter
// byte 처리 등등 기타 여러 HttpMessageConverter가 기본으로 등록
@GetMapping("hello-api")
@ResponseBody
public Hello helloApi(@RequestParam("name") String name) {
Hello hello = new Hello();
hello.setName(name);
return hello;
}
static class Hello {
private String name;
// getter, setter, property 접근 방식
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
}
}
- @ResponseBody를 사용하고, 객체를 반환하면 객체가 JSON으로 변환됨
package hello.demo.controller;
import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.ResponseBody;
@Controller
public class HelloController {
// API 방식
@GetMapping("hello-string")
// ResponseBody : http에서 head부분과 body부분이 있는데, 그 body부분에 데이터를 직접 넣어 주겠다!
// view가 없이 그대로 내려간다
@ResponseBody
public String helloString(@RequestParam("name") String name){
return "hello "+name;
}
static class Hello {
private String name;
// getter, setter, property 접근 방식
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
}
}
package hello.demo.controller;
import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.ResponseBody;
@Controller
public class HelloController {
// API 방식
// JSON 방식으로 객체 전달(key, value)
// xml은 무겁고 열고 닫고 태그를 두번써야 하는거에 비해 JSON은 객체 형식으로 심플하다
// 객체로 return하게 되면 ViewEesolve 대신에 HttpMessageConverter가 동작하면서 JsonConverter랑 StringConverter 중 JSON으로 자동 변환해서 전송한다
// 기본문자처리 : StringHttpMessageConverter
// 기본 객체처리 : MappingJackson2HttpMessageConverter
// byte 처리 등등 기타 여러 HttpMessageConverter가 기본으로 등록
@GetMapping("hello-api")
@ResponseBody
public Hello helloApi(@RequestParam("name") String name) {
Hello hello = new Hello();
hello.setName(name);
return hello;
}
static class Hello {
private String name;
// getter, setter, property 접근 방식
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
}
}
- @ResponseBody를 사용
- HTTP의 BODY에 문자 내용을 직접 반환
- viewResolvver 대신에 HttpMessageConverter가 동작
- 기본 문자 처리 : StringHttpMessageConver
- 기본 객체 처리 : Mapping.Jackson2HttpMessageConverter
- byte 처리 등등 기타 여러 : HttpMessageConveerter가 기본으로 등록되어 있음
참고 : 클라이언트의 HTTP Accept 헤더와 서버의 컨트롤러 반환 타입 정보 툴을 조합해서 HttpMessageConverter가 선택된다.
Author And Source
이 문제에 관하여(스프링 입문(7. API)), 우리는 이곳에서 더 많은 자료를 발견하고 링크를 클릭하여 보았다 https://velog.io/@ansalstmd/스프링-입문8.-API저자 귀속: 원작자 정보가 원작자 URL에 포함되어 있으며 저작권은 원작자 소유입니다.
우수한 개발자 콘텐츠 발견에 전념 (Collection and Share based on the CC Protocol.)