클라이언트와 서버의 통신

정홍섭·2023년 7월 22일
0

Backend

목록 보기
4/4
post-thumbnail

클라이언트와 서버

네트워크로 연결된 컴퓨터는 역할에 따라 클라이언트와 서버로 나눌수 있다.
웹에서 클라이언트는 웹 브라우저를 통해 검색하는 사용자이고
웹에서 서버는 검색 결과를 뜨워주고 인터페이스를 제공하는 포털사이트라고 보면 된다

클라이언트가 웹페이지에 접근하길 원할때,
서버는 클라이언트에게 웹브라우저로 보여지기 위한 웹페이지의 사본이 다운로드됨

브라우저가 하는 일은
1. 요청을 보낸다
2. 받은 HTML파일을 그려주는 일

웹은 html을 받는 경우도 있지만 Json형식으로 데이터만 받아와서 새로고침하는 경우가 많다

클라이언트와 서버의 통신 방법

  • HTTP(HyperText Transfer Protocol)
  • client 사용자 브라우저 → server에 request(요청)를 보낸다
  • server 서버 → client에 request(요청)에 대한 response(응답)를 웹으로 보낸다

AJAX

HTTP를 이용해 서버에서 데이터를 요청(request)해 받아올 수 있는 방법중 하나이다

Ajax는 서버와 클라이언트 간에 정보를 비동기적으로 전달하기 위해 자바스크립트에서 사용하는 라이브러리다

jquery를 이용하기 때문에 반드시 jquery를 import한 뒤 사용해야 한다

'비동기적으로 전달'한다는 것의 의미는
페이지를 새로고침하지 않고도 서버에 데이터를 요청한다는 뜻

Get과 Post방식

Get방식

  • 클라이언트에서 서버로 데이터를 전달할 때, 주소 뒤에 "이름"과 "값"이 결합된 스트링 형태로 전달

  • 주소창에 쿼리 스트링이 그대로 보여지기 때문에 보안성이 떨어진다

  • 길이에 제한이 있다(=전송 데이터의 한계가 있다)

  • Post방식보다 상대적으로 전송 속도가 빠르다

Post방식

  • 일정 크기 이상의 데이터를 보내야 할 때 사용한다

  • 서버로 보내기 전에 인코딩하고, 전송 후 서버에서는 다시 디코딩 작업을 한다

  • 주소창에 전송하는 데이터의 정보가 노출되지 않아 Get방식에 비해 보안성이 높다

  • 속도가 Get방식보다 느리다

  • 쿼리스트링(문자열) 데이터 뿐만 아니라, 라디오 버튼, 텍스트 박스 같은 객체들의 값도 전송가능

Get과 Post 차이점

  • Get은 주로 웹 브라우저가 웹 서버에 데이터를 요청할 때 사용

  • Post는 웹 브라우저가 웹 서버에 데이터를 전달하기 위해 사용

  • Get을 사용하면 웹 브라우저에서 웹 서버로 전달되는 데이터가 인코딩되어 URL에 붙는다

  • Post방식은 전달되는 데이터가 보이지 않는다

  • Get방식은 전달되는 데이터가 255개의 문자를 초과하면 문제가 발생할 수 있다

  • 웹서버에 많은 데이터를 전달하기 위해서는 Post 방식을 사용하는 것이 바람직하다

2개의 댓글

comment-user-thumbnail
2023년 7월 22일

정보 감사합니다.

답글 달기
comment-user-thumbnail
2023년 7월 25일

수고하셨습니다 HTTP 프로토콜을 각각의 역할을 구체적으로 적은 것이 좋았습니다

답글 달기