StringHttpMessageConverter가 사용될 때의 미디어 타입
[질문 템플릿]
1. 강의 내용과 관련된 질문인가요? (예)
2. 인프런의 질문 게시판과 자주 하는 질문에 없는 내용인가요? (예)
3. 질문 잘하기 메뉴얼을 읽어보셨나요? (예)
[질문 내용]

위 사진에서 StringHttpMessageConverter의 경우
미디어 타입은 별/별이라 써져 있고, 쓰기 미디어 타입은 text/plain이라고 나와 있습니다.
저는 처음에 위 부분을 다음처럼 이해했었습니다.
StringHttpMessageConverter가 요청을 받을 때 사용되는 경우(파라미터가 String인 경우) 요청 메시지의 Content-Type이 무엇이든 상관없다. StringHttpMessageConverter가 응답할 때 사용될 경우에도(리턴 타입이 String인 경우) 요청 메시지의 Accept가 무엇이든 상관없다.
StringHttpMessageConverter가 응답할 때 사용될 경우(리턴 타입이 String인 경우) 요청 메시지의 Accept가 특정한 거로 지정되어 있지 않다면 응답 메시지의 Content-Type이 text/plain으로 되지만, Accept가 지정되어 있다면 그에 맞는 미디어 타입(application/json 등)으로 나갈 수 있다.
원래 이렇게 생각했었는데, 다시 보니 pdf에 별/별이라고 되어 있는 미디어 타입은 요청 미디어 타입에 한정해서 써져 있는 건가?싶기도 해서 헷갈립니다. 그렇게 다시 해석한다면
StringHttpMessageConverter가 요청을 받을 때 사용되는 경우(파라미터가 String인 경우) 요청 메시지의 Content-Type은 아무 거나 상관없다. StringHttpMessageConverter가 응답할 때 사용될 경우(리턴 타입이 String인 경우) 요청 메시지의 Accept는 text/plain(혹은 이걸 포함한 별/별)이어야 하며 다른 미디어 타입은 허용하지 않는다.
전자와 후자 중 어떤 게 맞나요? 혹은 제가 쓴 양쪽 내용 다 잘못된 내용을 포함한다면 무엇인지 궁금합니다. 저는 전자일 것 같기는 합니다. 이전에 produces 관련 코드를 작성할 때 String으로 반환하는데도 produces = "text/plain"이 아닌 produces = "text/html"로 썼기 때문에요.
그런데 확신이 안 들어서 질문드립니다.
답변 2
2
안녕하세요. 11 1님
요청의 경우 String, byte[]는 모든 미디어 타입을 받을 수 있습니다.
여기서 쓰기 미디어타입이라는 것은 응답을 할 때 content-type을 뜻합니다.
감사합니다.
1
답변 감사합니다. 그러면 StringHttpMessageConverter가 응답할 때 사용될 경우(리턴 타입이 String인 경우) 요청 메시지의 Accept는 text/plain(혹은 이걸 포함한 별/별)이어야 하며 다른 미디어 타입은 허용하지 않는다.
이게 맞는 말인 건가요? 그러면 Accept나 produces가 text/plain이 아니라 text/html인 경우에는 StringHttpMessageConverter가 아니라 다른 메시지 컨버터가 쓰인다고 보면 될까요?
2
요청 메시지의 Accept는 text/plain이 아니어도 괜찮습니다.
Accept를 지정하지 않거나 모든 타입으로 지정하면 기본 값인 text/plain을 사용하고 Accept를 지정하면 해당 Accept 타입으로 반환합니다.
예를 들어서 Accept를 text/html으로 지정하면 content-type을 text/html로 반환합니다. 이러한 이유는 String 타입은 text/html도 되고, text/plain 될 수 있기 때문입니다. (둘다 문자로 만들어짐)
물론 produces를 지정하면 해당 타입에 맞는 컨트롤러 매핑이 존재해야겠지요?
감사합니다.
2
아 그럼 ByteArrayHttpMessageConverter, StringHttpMessageConverter 쓰기 미디어 타입에 써진 application/octet-stream이나 text/plain은 기본값이라고 생각하면 되겠네요..
답변 감사합니다!
0
안녕하세요, 인프런 AI 인턴입니다.
11님의 질문에 대해 확인해보니, StringHttpMessageConverter와 관련된 요청 및 응답 시 사용되는 미디어 타입에 대한 이해와 관련하여 혼동이 있는 것 같습니다. StringHttpMessageConverter는 기본적으로 text/*와 */* 미디어 타입을 지원하며, 나오는 응답에 대한 Content-Type은 설정에 따라 다를 수 있습니다.
위 질문과 유사한 맥락의 내용으로, 아래의 본 사이트에서 확인할 수 있는 유사한 질문들을 찾을 수 있었습니다:
- “요청이 String이고 응답이 객체 형태일 때 메시지 컨버터” – 요청과 응답에서 다른 메시지 컨버터가 사용될 수 있음을 설명하고 있으며, 요청이
text/plain인 경우에도 응답의Content-Type은application/json으로 할 수 있다는 점을 논의합니다.
- “requestBodyJson의 HttpMessageConverter 처리에 관하여” –
Content-Type이 지정되지 않은 경우StringHttpMessageConverter가 처리할 수 있다는 내용과 HTTP 메시지 컨버터의 동작 방식에 대해 언급합니다.
위의 내용을 통해 질문자님이 1번으로 생각한 내용이 맞다고 볼 수 있겠습니다. 요청을 받을 때, StringHttpMessageConverter는 거의 모든 Content-Type을 처리할 수 있고, 응답을 할 때는 요청의 Accept 헤더가 지정되어 있지 않다면 text/plain으로 응답합니다. 그러나, Accept 헤더가 지정되어 있다면 해당 미디어 타입에 맞게 응답을 설정할 수 있습니다.
저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.
servlet과 container에 대한 질문입니다
0
25
1
api를 어느 컨트롤러에 작성해야하는지는 어떤 기준으로 해야하나요?
0
64
1
jsp 의존성 수정 요청
0
80
2
요즘 웹 서버가 주로 사용되는 이유는 SPA 구조 때문일까요 ?
0
143
1
save() 메서드 문의
0
67
1
절대 경로로 templates/basic 하위 파일 열면 css 적용 안되는 현상
0
101
1
request-body-json
0
83
2
MVC 패턴의 적용 단위
0
97
1
RequestMapping을 이용한 핸들러, 어댑터
0
119
2
save 후 결과화면
0
89
2
jsp를 이용한 view
0
97
1
application.properties에 debug 추가해도 결과가 똑같습니다.
0
178
1
수업 코드 제공 관련 문의
0
97
2
RequestMappingHandlerAdapter의 Controller 호출 과정
0
100
3
파일 오픈 시
0
70
1
스프링 배치 관련
0
78
1
@RequestParam의 defaultValue가 blank 값도 처리하는 지 여부
0
112
1
postman으로 /request-body-json-v1 호출시 500 error
0
96
1
프론트엔드와 백엔드의 mvc, rest api에 대한 질문
0
79
1
모델의 역할과 계층 분리에 대한 이해 차이 + 추가질문
0
111
1
console log 출력 관련 질문입니다.
0
75
1
애플리케이션이 실행 되지 않습니다 ㅠㅠㅠ
0
139
1
html 변경하는 부분 적용 문제
0
103
1
한글 깨짐
0
77
2





