웹 상에서 클라이언트와 서버 간 데이터를 주고받는 데 사용되는 통신 규약
클라이언트가 서버에 요청을 보내고, 서버가 이에 대한 응답을 반환하는 방식으로 동작
비연결성(stateless)을 특징으로 하여 한 번의 요청-응답이 끝나면 연결이 종료됨
또한,
통신이 안전하게 연결될 수 있도록 TCP 연결을 사용
HTML, JSON 등 다양한 데이터 포맷을 전달할 수 있음
요청과 응답에는 URL 경로, 각종 메서드, 상태 코드와 헤더 등 정해진 몇 가지 정보를 포함함
HTTP의 보안을 강화한 버전인 HTTPS(Hypertext Transfer Protocol Secure) 는 HTTP에 TLS/SSL 프로토콜에 따라 데이터를 암호화하여 전송
이를 통해 보안 상 중요한 정보들을 안전하게 보호하여 통신을 주고 받음
Rest(Representational State Transfer)스타일을 준수하여 설계된 API
여기서 REST는 웹의 리소스를 클라이언트와 서버가 일관된 방식으로 처리할 수 있도록 하는 설계 원칙
기본적으로 REST에선 리소스를 고유한 URI로 표현, HTTP 메서드(GET,POST,PUT,DELETE 등)를 사용해 행위를 표현
ex - /users URI에 GET 요청을 보내면 사용자 목록을 가져오는 API로 동작함
REST의 핵심 규칙
1. 클라이언트-서버 분리:클라이언트와 서버 간 역할을 명확히 분리
2. 무상태성(Stateless): 서버는 클라이언트의 상태를 저장하지 않으며, 각 요청은 독립적으로 처리함
3. 일관된 인터페이스(Uniform Interface): 고유한 URI로 리소스를 식별하고 일관된 인터페이스를 통해 클라이언트와 서버가 간단하고 예측 가능하게 통신
4. 캐시 가능성: 가능하면, 서버의 응답 시간을 개선하기 위해 리소스 캐싱을 지원