RESTClientFlow.png REST 클라이언트 라이브러리(이하 REST 클라이언트)는 REST 기반 웹서비스와 연동하기 위한 프레임워크입니다. 이 라이브러리는 델파이에서 지원하는 모든 플랫폼에서 사용할 수 있습니다.(XE5 부터 지원시작)

 

이 프레임워크는 공식적으로 JSON 기반의 데이터를 지원합니다.

 

주요 컴포넌트 및 클래스

REST 클라이언트는

  • 요청과 응답에 관련된 3개의 주요 컴포넌트와
  • 응답 데이터(JSON)를 데이터셋으로 변환하는 컴포넌트,
  • 인증과 관련된 4개의 컴포넌트를 제공합니다.

 

TRESTClient

서비스에 대한 요청을 실제로 수행하는 컴포넌트입니다. 서비스에 대한 HTTP 연결을 관리하고, HTTP 해더 및 프록시 서버를 처리하고 응답 데이터를 받습니다. 인증 컴포넌트를 지정해 요청에 대한 인증 데이터를 손쉽게 추가할 수 있습니다.

 

주요 속성

  • BaseURL : 서비스 URL 중 변경되지 않는 정보를 입력합니다.(프로토콜, 도메인/호스트, 포트 등)
  • Authenticator : 인증 컴포넌트를 지정해 인증 정보를 추가할 수 할 수 있습니다.
  • UserAgent : 사용자 에이전트

 

TRESTRequest - 요청

서비스에 대한 실제 HTTP 요청에 대한 정보를 설정합니다. 여러가지의 요청을 위해 여러개의 컴포넌트로 구성할 수 있습니다. Client 속성에 지정된 TRESTClient의 BaseURL과 TRESTRequest의 Resouce, Method 속성을 조합해 요청을 합니다. Resource에 중괄호를 이용해 파라미터화 할 수 있습니다.

 

주요 속성

  • Resource : 요청할 서비스의 리소스의 경로, 중괄호({})로 파라미터화 가능
  • Method : 요청의 HTTP 메소드(GET, POST, PUT, DELETE, PATCH)
  • Params : 리소스의 파라미터를 지정할 수 있는 목록
  • Client : TRESTClient 지정
  • Response : 응답 컴포넌트 지정
  • Accept / AcceptCharset / AcceptEncoding : 응답에 사용할 수 있는 내용의 종류 / 캐릭터셋 / 인코딩 타입을 지정

 

TRESTResponse - 응답

서비스에서 반환된 데이터를 보관합니다. 이 데이터에는 HTTP 상태 코드와 오류메시지(있는 경우)를 포함합니다. 

 

주요 속성

  • Content : 응답받은 데이터를 보관
  • ContentLength : 응답받은 데이터의 길이
  • ContentType : 응답받은 데이터의 타입
  • RootElement : 응답받은 JSON 데이터 중 사용할 항목 지정 가능

 

TRESTResponseDataSetAdapter

서비스의 응답 데이터가 JSON 형식인 경우, 응답 데이터를 분석하고 그 데이터를 TDataSet(TFDMemTable 등)에 전송합니다.

내부의 파서는 JSON 객체와 JSON 객체의 배열을 찾습니다. 파서는 RootElement에 설정된 JSON 객체 또는 배열의 키로 필드를 만들고 값으로 레코드를 생성합니다. 객체의 경우 레코드 1개가 배열의 경우 배열의 길이만큼 레코드가 생성됩니다.

 

주요 속성

  • RootElement : 변환할 데이터 중 사용할 항목을 지정합니다.
  • Response : 변환할 데이터를 보관한 TRESTResponse 지정
  • Dataset : 분석한 데이터를 보관(전송)할 데이터셋 지정

 

인증 컴포넌트

대부분의 서비스는 사용 전 인증이 필요합니다. REST 클라이언트는 서비스에서 요구하는 인증방법을 컴포넌트 기반으로 설정 해 TRESTClient의 Authenticate 속성에 지정할 수 있습니다.

다음 인증 컴포넌트를 제공합니다.

  • TSimpleAuthenticator : 사용자 이름과 패스워드 등의 입력 필드를 가진 HTML 폼과 같은 기본적인 인증방식 구현
  • THTTPBasicAuthenticator : HTTP 기본 인증 처리
  • TOAuth1Authenticator, TOAuth2Authenticator : OAuth1/2 인증 컴포넌트, 서비스 공급사의 웹페이지로 로그인 후 토큰을 발급받아 인증하는 방식
  • 커스텀 인증 클래스 생성 : TCustomAuthenticator를 상속받아 DoAuthenticate 메소드를 재정의

 

기타 참고자료

데브기어 기술자료

엠바카데로 기술자료

 
번호 제목 글쓴이 날짜 조회 수
공지 [DelphiCon 요약] 코드사이트 로깅 실전 활용 기법 (Real-world CodeSite Logging Techniques) 관리자 2021.01.19 15441
공지 [UX Summit 요약] 오른쪽 클릭은 옳다 (Right Click is Right) 관리자 2020.11.16 13962
공지 [10.4 시드니] What's NEW! 신기능 자세히 보기 관리자 2020.05.27 16499
공지 RAD스튜디오(델파이,C++빌더) - 고객 사례 목록 관리자 2018.10.23 22055
공지 [데브기어 컨설팅] 모바일 앱 & 업그레이드 마이그레이션 [1] 관리자 2017.02.06 23268
공지 [전체 목록] 이 달의 기술자료 & 기술레터 관리자 2017.02.06 18923
공지 RAD스튜디오(델파이, C++빌더) - 시작하기 [1] 관리자 2015.06.30 39257
공지 RAD스튜디오(델파이,C++빌더) - 모바일 앱 개발 사례 (2020년 11월 업데이트 됨) 험프리 2014.01.16 174713
106 파이어 몽키 이퀼라이저 데모 동영상 박병일 2012.02.06 10064
105 Delphi XE5 and RAD Studio XE5 Android and iOS Code Samples Humphery 2013.12.14 9353
104 파이어몽키 써드파티 라이브러리 ApeSuite file 박병일 2012.02.06 9116
103 파이어몽키를 이용해서 아이폰앱을 개발할때 스타일 바꾸기 관리자 2012.04.19 8972
102 Firemonkey MAC OSX 에서 ComboBox 다운현상 [2] c2design 2012.03.28 8339
101 VCL 폼을 파이어몽키 폼으로 바꿀수 있는 컨버터 프로그램 file 박병일 2012.03.01 8328
100 [참고] MAC OSX 어플리케이션 프로젝트 경로 문제 [1] c2design 2012.03.23 8142
99 [참고] MAC OSX 에서 ExtractFileName 사용시 주의점. [1] c2design 2012.03.23 7725
98 파이어몽키와 VCL을 한 화면에서 함께 사용할 수 있는 방법을 설명한 동영상 [2] 관리자 2012.05.09 7573
97 앤더슨 올슨이 아이폰용 컴포넌트의 새버전을 오픈 했습니다. [3] file 관리자 2012.05.09 7394
96 [세미나자료] 20120508 "Mac과 윈도우를 동시에… 동일한 소스코드로 멋지게 개발" file 관리자 2012.05.10 7324
95 [개발보고] 델파이 안드로이드 앱 출시 기술정보 [7] file c2design 2013.11.08 7103
94 사다리게임 소스와 함께 오픈(iOS, 구글 마켓 등록완료) [2] file c2design 2014.05.27 7006
93 모바일 Bluetooth 연동 자료 Humphery 2014.06.24 7002
92 파이어몽키용 TMS 그리드의 간략한 소개 백서 관리자 2012.09.26 6867
91 3줄의 코드로 "움직이는 3D 컬러애벌레" 만들기 관리자 2012.07.12 6864
90 안드로이드 - 장비 부팅 시 앱을 자동시작(링크) Humphery 2014.01.15 6635
89 파이어몽키에서 미디어 플레이어 개발 관련 Humphery 2013.12.18 6600
88 [안드로이드] 네트워크 연결 상태 체크 함수. [1] c2design 2013.10.29 6489
87 David I의 31일 동영상(한글자막) - TLang컴포넌트로 다국어 파이어몽키 앱 만들기(델파이 동일 적용) [1] 관리자 2013.05.06 6430