백엔드

웹 프로그래밍 기초 - URL과 웹 페이지, 웹 브라우저와 웹 서버, HTML과 HTTP, 정적 자원과 동적 자원

책 읽는 개발자_테드 2021. 10. 2. 15:17
반응형

학습 목표

- URL과 웹페이지

- 웹 브라우저와 웹 서버

- HTML과 HTTP

- 정적 자원과 동적 자원


URL과 웹페이지

· URL: Uniform Resource Locator(통합 자원 위치)의 약자로 일종의 주소와 같은 역할

   -  https://www.tistory.com/ , https://www.google.com/ 과 같이 웹브라우저 주소줄에 표시되는 것   

 

· 웹페이지: 웹 브라우저에 URL에 해당하는 내용이 출력되는 것

· 홈페이지, 웹 사이트: 웹 페이지의 묶음

 

· URL의 주요 구성 요소

구성 요소 설명
프로토콜 · 웹 브라우저가 서버와 내용을 주고받을 때 사용할 규칙 이름
서버 이름 · 웹 페이지를 요청할 서버의 이름 지정
· 도메인 이름(예:tistory.com) 또는 180.70.134.239와 같은 IP 주소 입력 
경로 · 웹 페이지의 상세 주소
쿼리 문자열 · 추가로 서버에 보내는 데이터
· 같은 경로에서 입력한 값에 따라 다른 결과를 보여줄 때 사용
ex) 검색 결과를 보여주는 페이지

· URI(identifier) vs URN(name) vs URL(location)

URI(Uniform Resource Identifier) ​​=> https://www.google.com/folder/page.html
URL(Uniform Resource Locator) => https://www.google.com/
URN(Uniform Resource Name) => /folder/page.html

https://prateekvjoshi.com/2014/02/22/url-vs-uri-vs-urn/

 

자세한 내용

https://www.charlezz.com/?p=44767

https://stackoverflow.com/questions/176264/what-is-the-difference-between-a-uri-a-url-and-a-urn

 

웹 브라우저와 웹 서버

· 웹 브라우저에 URL을 입력하면, 웹 서버 프로그램이 웹 브라우저에 웹 페이지를 제공함

 

https://sleepyeyes.tistory.com/13

· 웹 브라우저가 웹 서버에 웹 페이지를 달라고 하는 것을 요청(request), 

요청한 웹 페이지를 웹 브라우저에 제공하는 것을 응답(response)이라고 표현

· IP 주소: 웹 브라우저와 웹 서버를 연결하기 위해 필요한 웹 서버가 실행 중인 컴퓨터의 주소 ex)180.70.134.239

· 도메인 이름: IP 주소는 숫자로 구성되어 외우기 어렵기 때문에 사용되는 문자(0~9, a~z, 하이픈)로 이루어진 주소 이름

· DSN(Domain Name Server): 도메인 이름을 IP 주소로 변환하는 서버

· 포트(port): 한 개의 컴퓨터의 웹 서버, 스트리밍 서버, 채팅 서버 등 다양한 서버 프로그램이 존재할 수 있으므로,

클라이언트와 서버 프로그램을 연결할 때 다른 서버 프로그램과 구분할 수 있도록 포트를 사용

 

HTML과 HTTP

· HTML(HyperText MarkUp Language):  웹 페이지의 모습을 기술하기 위한 규약

· 렌더링(Rendering): 웹서버에서 전송한 HTML 문서를 받은 웹 브라우저에서 이를 분석하여,

HTML 표준 규칙에 따라 알맞은 화면을 생성하는 과정

· HTTP(HyperText Transfer Protocol): 클라이언트와 웹 서버가 HTML, 이미지, 동영상, XML 문서 등

다양한 데이터를 주고받을 때 사용하는 규칙

   - 요청 규칙: 클라이언트가 웹 서버에 데이터를 요청할 때 사용할 데이터 구성 규칙

   - 응답 규칙: 웹 서버가 클라이언트에 데이터를 전송할 때 사용할 데이터 구성 규칙

https://m.blog.naver.com/PostView.naver?isHttpsRedirect=true&blogId=moongmoong_2&logNo=221356141557

· HTTP 요청 데이터와 응답 데이터

구성 요소 요청 데이터 응답 데이터 예시
요청/응답 줄 · GET, POST 같은 HTTP 요청 방식과 요청하는 자원의 경로 지정 · 요청에 대한 응답 코드 전송
ex) 200
GET / HTTP/1.1 (요청)
HTTP/1.1 200 OK (응답)
헤더 · 서버가 응답을 생성하는데 참조할 수 있는 정보 전송
ex) 브라우저의 종류, 언어 정보 등
· 응답에 대한 정보 전송
ex) 몸체의 데이터, 길이 등의 정보
Host: www.daum.net  
Date: Wed, 22 Apr 2015 ~
몸체 · 정보를 전송해야 할 때 사용
ex) 파일 업로드시 몸체에 파일을 담아 웹서버에 전송
· 웹 브라우저가 요청한 자원의 내용을 담음 
ex) HTML 문서, 이미지 파일, 데이터 등 
<!DOCTYPE html>
<html lang= "ko">
~~~

· 헤더 영역은 요청/응답 줄 다음에 위치하며, "헤더이름:헤더 값"으로 구성

· 헤더가 끝난 후 빈 줄이 오고 그 다음 몸체 내용이 온다

 

정적 자원과 동적 자원

· 정적(static) 자원 또는 페이지: URL로 요청했을 때 고정된 결과가 출력되는 자원

ex) HTML 파일 등

· 동적(dynamic) 자원 또는 페이지: URL로 요청했을 때 시간 등 특정 조건에 따라 응답 데이터가 달라지는 자원

ex) PHP, JSP 등

 

출처

최범균의 JSP 2.3 웹 프로그래밍: 기초부터 중급까지

 

반응형