inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

스프링 MVC 1편 - 백엔드 웹 개발 핵심 기술

섹션 7. post

해결된 질문

131

권정익

작성한 질문수 60

0

<form action="item.html" th:action method="post">
    <div>
        <label for="itemName">상품명</label>
        <input type="text" id="itemName" name="itemName" class="formcontrol" placeholder="이름을 입력하세요">
    </div>
    <div>
        <label for="price">가격</label>
        <input type="text" id="price" name="price" class="form-control"
               placeholder="가격을 입력하세요">
    </div>
    <div>
        <label for="quantity">수량</label>
        <input type="text" id="quantity" name="quantity" class="formcontrol" placeholder="수량을 입력하세요">
    </div>
    <hr class="my-4">
    <div class="row">
        <div class="col">
            <button class="w-100 btn btn-primary btn-lg" type="submit">상품 등
                록</button>
        </div>
        <div class="col">
            <button class="w-100 btn btn-secondary btn-lg"
                    onclick="location.href='items.html'"
                    th:onclick="|location.href='@{/basic/items}'|"
                    type="button">취소</button>
        </div>
    </div>
</form>

여기서 method="post"인데 html 폼 데이터로 전송된다고 교재에 적혀있는데, 요청 데이터 전송에는

Get 파라미터

html 데이터 폼 전송

http api 형식 데이터 전송

3가지중 Post이기에 Get은 아니지만, 왜 미디어 타입에 관한 건 명시되어 있지않은데, 왜 무조건 html 폼 데이터로 전송 되는 건가요?

spring mvc

답변 1

1

인프런 AI 인턴

안녕하세요, 인프런 AI 인턴입니다.

권정익님의 질문은 HTML <form> 태그의 데이터 전송 방식과 관련이 있는 것으로 보입니다. 특히 method="post"일 때, 데이터가 어떤 형식으로 전송되는지에 대한 질문인 것 같습니다.

HTML 폼이 데이터를 전송하는 방식은 주로 GETPOST 두 가지입니다. 여기서 method 속성 값으로 POST를 지정하면, 폼 데이터가 HTTP 요청의 본문(body)을 통해 전송됩니다. 대부분의 경우, 이 데이터 형식은 application/x-www-form-urlencoded 또는 multipart/form-data입니다.

application/x-www-form-urlencoded는 폼 데이터가 쿼리 스트링 형식으로 인코딩되어 전송되는 것을 의미합니다. 즉, 키-값 쌍이 &로 구분되고, 각 키와 값은 =로 연결됩니다. 이 형식은 텍스트 데이터 전송에 적합합니다.

multipart/form-data는 파일이나 대용량 데이터를 전송할 때 주로 사용됩니다. 각 폼 필드와 파일이 파트로 나누어져 전송됩니다.

HTML 폼의 enctype 속성으로 이들 중 하나를 선택할 수 있으며, 지정하지 않으면 기본값은 application/x-www-form-urlencoded입니다. 따라서, 권정익님의 코드에서 enctype 속성이 명시되지 않았다면, 기본적으로 application/x-www-form-urlencoded 형식으로 데이터가 전송되는 것입니다.

이에 대한 좀 더 자세한 설명은 HTML

enctype Attribute에서 확인하실 수 있습니다.

저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다. 현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏 추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.

servlet과 container에 대한 질문입니다

0

21

1

api를 어느 컨트롤러에 작성해야하는지는 어떤 기준으로 해야하나요?

0

62

1

jsp 의존성 수정 요청

0

75

2

요즘 웹 서버가 주로 사용되는 이유는 SPA 구조 때문일까요 ?

0

142

1

save() 메서드 문의

0

65

1

절대 경로로 templates/basic 하위 파일 열면 css 적용 안되는 현상

0

99

1

request-body-json

0

83

2

MVC 패턴의 적용 단위

0

94

1

RequestMapping을 이용한 핸들러, 어댑터

0

118

2

save 후 결과화면

0

86

2

jsp를 이용한 view

0

97

1

application.properties에 debug 추가해도 결과가 똑같습니다.

0

175

1

수업 코드 제공 관련 문의

0

97

2

RequestMappingHandlerAdapter의 Controller 호출 과정

0

98

3

파일 오픈 시

0

68

1

스프링 배치 관련

0

77

1

@RequestParam의 defaultValue가 blank 값도 처리하는 지 여부

0

112

1

postman으로 /request-body-json-v1 호출시 500 error

0

94

1

프론트엔드와 백엔드의 mvc, rest api에 대한 질문

0

77

1

모델의 역할과 계층 분리에 대한 이해 차이 + 추가질문

0

111

1

console log 출력 관련 질문입니다.

0

73

1

애플리케이션이 실행 되지 않습니다 ㅠㅠㅠ

0

138

1

html 변경하는 부분 적용 문제

0

100

1

한글 깨짐

0

76

2