일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | ||||
4 | 5 | 6 | 7 | 8 | 9 | 10 |
11 | 12 | 13 | 14 | 15 | 16 | 17 |
18 | 19 | 20 | 21 | 22 | 23 | 24 |
25 | 26 | 27 | 28 | 29 | 30 | 31 |
- 객체의비교
- 인프런무료강좌
- 인프런인강
- 자바스크립트객체리터럴
- 객체리터럴
- EntityFramework
- 자바스크립트파라미터
- 고차함수
- 자바스크립트
- c#
- 인터넷프로토콜
- 인프런자바스크립트
- 자바스크립트recude
- 콜백함수
- NPM
- 인프런강의
- 제로초
- Blazor
- 이벤트리스너
- sort
- slice
- 인프런
- 비주얼스튜디오
- .NET
- HTTP
- 틱택토구현
- 자바스크립트함수
- 자바스크립트틱택토
- 인프런강좌
- 코딩
- Today
- Total
목록스프링 MVC 1편 -인프런 김영한 (10)
샐님은 개발중
1. HTTP 메세지 컨버터 - HTTP API 처럼 JSON 데이터를 HTTP 메시지 바디에서 직접 읽거나 쓰는 경우 HTTP 메시지 컨버터를 사용하는 편리. @ResponseBody 사용 원리 - HTTP 의 BODY에 문자 내용을 직접 반환 - viewResolver 대신 HttpMessageConverter 가 동작 - 기본 문자처리 : StringHttpMessageonverter , 기본 객체처리 : MappingJackson2HttpMessageConverter (json) 처리 - btye 처리 등 기타 여러 HttpMessageconverter 가 기본으로 등록되어 있다. - 응답의 경우 클라이언트의 HTTP Accept 헤더와 서버의 컨트롤러 반환 타입 정보 둘을 조합해 HttpMess..
responseBodyV1 서블릿을 직접 다룰 때 처럼 HttpServletResponse 객체를 통해서 HTTP 메시지 바디에 직접 ok 응답 메시지를 전달. responseBodyV2 ResponseEntity 엔티티는 HttpEntity 를 상속 받고 HttpEntity는 HTTP 메시지의 헤더, 바디 정보를 가지고 있다. ResponseEntity 는 여기에 더해서 HTTP 응답 코드를 설정할 수 있다. HttpStatus.CREATED 로 변경하면 201 응답이 나가는 것을 확인할 수 있다. responseBodyV3 @ResponseBody 를 사용하면 view를 사용하지 않고, HTTP 메시지 컨버터를 통해서 HTTP 메시지를 직접 입력할 수 있다. ResponseEntity 도 동일한 방식..
스프링 (서버)에서 응답 메시지를 만드는 3가지 방법 정적 리소스 예) 웹 브라우저에 정적인 HTML, css, js제공 . 뷰 템플릿 사용 예) 웹 브라우저에 동적인 HTML을 제공할 때는 뷰 템플릿을 사용. HTTP 메시지 사용 HTTP API를 제공하는 경우에는 HTML이 아니라 데이터를 전달해야 하므로, HTTP 메시지 바디에 JSON 같은 형식으로 데이터를 실어 보낸다 1. String을 반환하는 경우 - View or HTTP 메시지 @ResponseBody 가 없으면 response/hello 로 뷰 리졸버가 실행되어서 뷰를 찾고, 렌더링 한다. @ResponseBody 가 있으면 뷰 리졸버를 실행하지 않고, HTTP 메시지 바디에 직접 response/hello 라는 문자가 입력된다. 여기..
1. requestBodyJsonV1 : HttpServletRequest를 사용해 직접 http 메시지 바디에서 데이터를 읽어와서 문자로 변환한다. 문자로된 json 데이터를 Jackson 라이브러리인 objectMapper 를 사용해서 자바 객체로 변환한다. 2.requestBodyJsonV2 - @RequestBody 문자 변환 @RequestBody 를 사용해서 HTTP 메시지에서 데이터를 꺼내고 messageBody에 저장 3.requestBodyJsonV3 - @RequestBody 객체 변환 @RequestBody 객체 파라미터 @RequestBody HelloData data @RequestBody 에 직접 만든 객체를 지정 HttpEntity , @RequestBody 를 사용하면 HTT..
HTTP message body 에 데이터를 직접 담아서 요청 -http api 에서 주로 사용, json, xml, text -데이터 형식은 주로 json 사용 - post, put, patch 요청 파타미터와 다르게 http 메시지 바디를 통해 데이터가 직접 넘어오는 경우는 @RequestParam , @ModelAttribute 를 사용할 수 없다. (물론 HTML Form 형식으로 전달되는 경우는 요청 파라미터로 인정된다.) package hello.springmvc.basic.request; import jakarta.servlet.ServletInputStream; import jakarta.servlet.http.HttpServletRequest; import jakarta.servlet.h..
실제로는 요청 파라미터의 값을 받아서 객체에 값을 넣어주어야 한다. 기존 코드 @RequestParam String username; @RequestParam int age; HelloData data = new HelloData(); data.setUsername(username); data.setAge(age) 이것을 자동화해주는 @ModelAttribute 기능을 제공한다. 수정전 @ResponseBody @RequestMapping("/model-attribute-v1") public String modelAttributeV1(@RequestParam String username, @RequestParam int age){ HelloData hellodata = new HelloData(); he..

1. 클라이언트에서 서버로 요청 데어티 전달 방법 3가지 1) GET - 쿼리 파라미터 - url의 쿼리 파라미터에 데이터 포함해서 전달, 검색, 필터, 페이징에서 많이 사용하는 방식 2) POST - HTML Form - 메시지 바디에 쿼리 파라미터 형식으로 전달 . 회원 가입, 상품 주문, html form 사용 3) HTTP message body 에 데이터 담음 - http api 에서 주로 사용, json, xml, text. 데이터 형식은 주로 json 사용. post , put, patch * 요청파라미터 - 쿼리 파라미터, HTML Form 2. 스프링으로 요청파라미터 조회 방법 package hello.springmvc.basic.request; import jakarta.servlet...
1. HTTP 헤더 정보 조회 package hello.springmvc.basic.request; import jakarta.servlet.http.HttpServletRequest; import jakarta.servlet.http.HttpServletResponse; import lombok.extern.slf4j.Slf4j; import org.springframework.http.HttpMethod; import org.springframework.util.MultiValueMap; import org.springframework.web.bind.annotation.CookieValue; import org.springframework.web.bind.annotation.RequestHeader..
1. 특정 파라미터, 특정 헤더 조건 등으로 매핑 예시 @RestController - 반환값으로 뷰를 찾는 것이 아니라 HTTP 메세지 바디에 바로 입력한다. package hello.springmvc.basic.requestmapping; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import org.springframework.web.bind.annotation.*; @RestController public class MappingController { private Logger log = LoggerFactory.getLogger(getClass()); @RequestMapping(value = "/hello-basic", method =..

1. https://start.spring.io/ 에서 프로젝트 생성 Jar - 항상 내장 서버 사용가능, 'webapp' 경로도 사용하지 않는다. 내장 서버 사용에 최적화되어있다. War - 내장 서버 사용가능, 주로 외부 서버에 배포하는 목적으로 사용. 1. 로깅 - 로깅 라이브러리를 사용해서 로그를 출력 로깅 라이브러리 스프링 부트 라이브러리를 사용하면 스프링 부트 로깅 라이브러리가 함께 포함된다. SLF4J는 인터페이스이고 그 구현체로 Logback 과 같은 로그 라이브러리를 선택하면 된다. 실무에서는 스프링 부트가 기본으로 제공하는 Logback을 대부분 사용한다. package hello.springmvc.basic; import lombok.extern.slf4j.Slf4j; import o..