해결된 질문
작성
·
119
0
1.------------------------------------------------------------------------------------
Host: localhost:8080
Connection: keep-alive
Content-Length: 18
Cache-Control: max-age=0
sec-ch-ua: "Microsoft Edge";v="125", "Chromium";v="125", "Not.A/Brand";v="24"
sec-ch-ua-mobile: ?0
sec-ch-ua-platform: "Windows"
Upgrade-Insecure-Requests: 1
Origin: http://localhost:8080
Content-Type: application/x-www-form-urlencoded
User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/125.0.0.0 Safari/537.36 Edg/125.0.0.0
Accept: text/html,application/xhtml+xml,application/xml;q=0.9,image/avif,image/webp,image/apng,*/*;q=0.8,application/signed-exchange;v=b3;q=0.7
Sec-Fetch-Site: same-origin
Sec-Fetch-Mode: navigate
Sec-Fetch-User: ?1
Sec-Fetch-Dest: document
Referer: http://localhost:8080/servlet/members/new-form
Accept-Encoding: gzip, deflate, br, zstd
Accept-Language: ko,en;q=0.9,en-US;q=0.8
Cookie: Idea-9dddef07=3ad833a2-9560-44ed-926b-2edd236efc95
username=leo&age=5]
MemberSaveServlet.service
1.------------------------------------------------------------------------------------
2024-06-14T15:50:37.558+09:00 DEBUG 25172 --- [servlet] [nio-8080-exec-6] o.a.coyote.http11.Http11InputBuffer : Before fill(): parsingHeader: [true], parsingRequestLine: [true], parsingRequestLinePhase: [0], parsingRequestLineStart: [0], byteBuffer.position(): [0], byteBuffer.limit(): [0], end: [959]
2024-06-14T15:50:37.558+09:00 DEBUG 25172 --- [servlet] [nio-8080-exec-6] o.a.coyote.http11.Http11InputBuffer : Received []
2024-06-14T15:50:37.558+09:00 DEBUG 25172 --- [servlet] [nio-8080-exec-6] o.apache.coyote.http11.Http11Processor : Socket: [org.apache.tomcat.util.net.NioEndpoint$NioSocketWrapper@12d81083:org.apache.tomcat.util.net.NioChannel@7860389b:java.nio.channels.SocketChannel[connected local=/[0:0:0:0:0:0:0:1]:8080 remote=/[0:0:0:0:0:0:0:1]:53734]], Status in: [OPEN_READ], State out: [OPEN]
2024-06-14T15:50:37.633+09:00 DEBUG 25172 --- [servlet] [nio-8080-exec-7] o.a.coyote.http11.Http11InputBuffer : Before fill(): parsingHeader: [true], parsingRequestLine: [true], parsingRequestLinePhase: [0], parsingRequestLineStart: [0], byteBuffer.position(): [0], byteBuffer.limit(): [0], end: [959]
2024-06-14T15:50:37.634+09:00 DEBUG 25172 --- [servlet] [nio-8080-exec-7] o.a.coyote.http11.Http11InputBuffer : Received [GET /favicon.ico HTTP/1.1
Host: localhost:8080
Connection: keep-alive
sec-ch-ua: "Microsoft Edge";v="125", "Chromium";v="125", "Not.A/Brand";v="24"
sec-ch-ua-mobile: ?0
User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/125.0.0.0 Safari/537.36 Edg/125.0.0.0
sec-ch-ua-platform: "Windows"
Accept: image/avif,image/webp,image/apng,image/svg+xml,image/*,*/*;q=0.8
Sec-Fetch-Site: same-origin
Sec-Fetch-Mode: no-cors
Sec-Fetch-Dest: image
Referer: http://localhost:8080/servlet/members/save
Accept-Encoding: gzip, deflate, br, zstd
Accept-Language: ko,en;q=0.9,en-US;q=0.8
Cookie: Idea-9dddef07=3ad833a2-9560-44ed-926b-2edd236efc95
]
늘 불철주야 강의 찍으시느라 고생하시는 지식공유자님과 답글 달아주시는 선생님들의 노고에 항상 감사드리는 마음으로 질문 남깁니다.
상황
1, /servlet/members/new-form 에 들어가서 username, age를 입력해서 전송을 누른다.
2, 전송 버튼을 누르면 서블릿에서 member를 저장하고 그 결과로 /servlet/members/save의 html메시지를 메시지 바디에 담아서 응답한다.
질문1:
전송버튼을 누르면 /servlet/members/save url로 요청이 들어가는 게 맞는 건가요?
질문2:
위 코드를 2개로 쪼갰습니다. /servlet/members/new-form에서 데이터를 입력하고 전송을 눌렀을 때 부터의 콘솔창 입니다.
/servlet/members/new-form에서 보낸 요청 -> /servlet/members/new-form에 대한 응답
으로 끝나야 하는데 요청이 두 개 들어온 거는 왜 그런 건가요??
답변 1
1
안녕하세요, 인프런 AI 인턴입니다.
질문1에 대한 답변입니다:
네, /servlet/members/new-form에서 폼 데이터를 전송하면 설정되어 있는 서블릿 혹은 컨트롤러에 의해 처리되고, 그 결과로 ‘/servlet/members/save’로 요청이 이동하는 것이 일반적입니다. 이는 폼 데이터를 처리하는 서브릿에서 처리 후 지정된 URL로 리다이렉트 혹은 디스패치 방식으로 이동시키기 때문입니다.
질문2에 대한 답변입니다:
요청이 두 번 들어온 것은 첫 번째 요청이 실제 데이터를 가지고 ‘/servlet/members/new-form’에서 처리한 뒤의 동작과, 브라우저가 자동으로 페이지에 포함된 다른 리소스(예: 파비콘)를 요청하기 때문일 수 있습니다. 보통 브라우저는 사이트의 아이콘인 파비콘을 가져오기 위해 ‘/favicon.ico’ 경로로 추가 요청을 보내는데, 이 때문에 서버에 두 번째 요청이 발생한 것으로 보입니다. 첫 번째 요청은 사용자가 제출한 데이터를 처리하는 주요 요청이고, 두 번째 요청은 브라우저가 자동으로 수행하는 리소스 요청입니다.
고맙습니다, 권정익님. 다른 궁금한 점이 있으면 언제든지 질문해주세요.