❤️ URI와 웹 브라우저 요청 흐름
URI❓ URL❓ URN❓
"URI는 로케이터(locator), 이름(name) 또는 둘 다 추가로 분류될 수 있다"
![](https://velog.velcdn.com/images/judyan/post/f135012f-b166-484b-adaa-a4172578b4d6/image.png)
![](https://velog.velcdn.com/images/judyan/post/263fe071-d958-4c8b-b3cb-3ad6f9a1ba22/image.png)
- Uniform : 리소스 식별하는 통일된 방식
- Resource : 자원, URI로 식별할 수 있는 모든 것(제한 없음)
- Identifier : 다른 항목과 구분하는데 필요한 정보
📝 URL, URN
- URL - Locator : 리소스가 있는 위치를 지정
- URN - Name : 리소스에 이름을 부여
- 위치는 변할 수 있지만, 이름은 변하지 않는다
ex ) urn:isbn:8960777331
(어떤 책의 isbn URN)
- URN 이름만으로 실제 리소스를 찾을 수 있는 방법이 보편화 되지 않음
- 앞으로 URI를 URL과 같음 의미로 생각하고 이해하면 됨
📝 URL 분석
https://www.google.com/search?q=hello&hl=ko
-> google에 hello를 검색한 결과가 나옴
📌 전체 문법
scheme://[userinfo@]host[:port][/path][?query][#fragment]
프로토콜 호스트명 포트번호 패스 쿼리파라미터
schema
- 주로 프로토콜 사용
- 프로토콜 : 어떤 방식으로 자원에 접근할 것인가 하는 약속 규칙 ex) http, https, ftp 등등
- http - 80포트, https - 443포트 주로 사용(포트 생략 가능)
- https는 http에 보안 추가(HTTP Secure)
userinfo
- URL에 사용자 정보를 포함해서 인증
- 거의 사용하지 않음
host
- 호스트명
- 도메인명 또는 IP주소 직접 사용가능
- ex) www.google.com
port
- 포트(PORT)
- 접속 포트
- 일반적으로 생략, 생략시 http는 80, https는 443
path
- 리소스 경로, 계층적 구조
- ex)
/home/file1.jpg
/members
/members/100
, /items/iphone15
query
- key=value형태
- ?로 시작, &로 추가 가능
?keyA=valueA&keyB=valueB
- query parameter, query string등으로 불림
웹서버에 제공하는 파라미터, 문자 형태
fragment
- html 내부 북마크 등에 사용
- 서버에 전송하는 정보 아님
📝 웹 브라우저 요청 흐름
- 웹 브라우저에 URL 입력
- IP, PORT 정보로 HTTP 요청 메시지 생성
![](https://velog.velcdn.com/images/judyan/post/5ab04bfe-9bec-4c6d-bfd6-caf241bdf0f8/image.png)
![](https://velog.velcdn.com/images/judyan/post/c58f2e91-a1e7-457d-bfec-cbac0a01e156/image.png)
- HTTP 메시지 전송
![](https://velog.velcdn.com/images/judyan/post/3e8473f8-6060-4a60-ac28-93e5110bcc0a/image.png)
- 패킷 생성
![](https://velog.velcdn.com/images/judyan/post/2d931ba7-f043-4bb3-87b7-2ec34d6c5bbf/image.png)
- 요청 패킷 전달
![](https://velog.velcdn.com/images/judyan/post/9353ad9b-89ac-4f24-8b9f-553a43eb26c4/image.png)
- 요청 패킷 도착
: 요청 패킷이 도착하면 TCP/IP패킷 제거후 HTTP메시지 해석 -> HTTP응답 메시지 생성
![](https://velog.velcdn.com/images/judyan/post/58a95103-cad4-46fe-8810-9f8e9062748b/image.png)
- 응답 패킷 전달
![](https://velog.velcdn.com/images/judyan/post/f02cc253-d7b5-492e-996a-730ef31d969c/image.png)
- 응답 패킷 도착
: 응답 패킷이 도착하면 웹 브라우저 HTML렌더링
![](https://velog.velcdn.com/images/judyan/post/a1ed79bd-642f-4c7e-bcd9-eb077ca56374/image.png)
출처 - 인프런 '모든 개발자를 위한 HTTP 웹 기본 지식' 강의