RAD 스튜디오 10.3 리오는 RAD 서버의 성능향상과 엔드 포인트 연동을 더 쉽고 유연하게 작성할 수 있는 특성등이 추가되었습니다.

 

엔드 포인트 메소드와 Content-Type, Accept 연동 특성 추가

커스텀 리소스에 요청 시 URL과 HTTP 메소드에만 의존하지 않고, HTTP 해더의 Accept 및 Cotnet-Type에 따라 엔드 포인트 메소드를 연결하는 특성이 추가되었습니다. 이제 동일한 URL 및 HTTP 메소드라도 Accept 및 Content-Type에 따라 다른 동작을 구현할 수 있습니다.

  • EndpointProduce : GET 메소드의 엔드 포인트에 추가할 수 있습니다. HTTP 해더의 Accept 항목 값과 일치하는 MIME 타입/파일 확장자를 파라메터로 지정합니다.
  • EndpointConsume : PUT / POST / PATCH 메소드의 엔드 포인트에 추가할 수 있습니다. HTTP 해더의 Content-Type 항목 값과 일치하는 MIME 타입/파일 확장자를 파라메터로 지정합니다.

코드 예제: 

 

type

  [ResourceName('Test')]

  TTestResource = class​​(TDataModule)

  public

    [ResourceSuffix('*')]

    [EndpointProduce('image/jpeg')]

    procedure​​ GetImage(const​​ AContext: TEndpointContext;

      const​​ ARequest: TEndpointRequest;

      const​​ AResponse: TEndpointResponse);

    [ResourceSuffix('*')] [EndpointProduce('application/pdf')]

    procedure​​ GetPdf(const​​ AContext: TEndpointContext;

      const​​ ARequest: TEndpointRequest;

end​​;const​​ AResponse: TEndpointResponse); 

커스텀 메소드와 HTTP 메소드 연결 특성 추가

RAD 서버의 이전 버전에서는 HTTP 메소드(GET, POST 등)의 엔드 포인트 메소드 이름과 매핑되었습니다.

이제 위 방식 외에도 다른이름의 메소드를 엔드 포인트 메소드로 매핑할 수 있는 EndpointMethod 특성이 추가되었습니다.

 

코드 예제:

 

type

  [ResourceName('Test')]

  TTestResource = class(TDataModule)

  public

    [EndpointMethod(TEndpointRequest.TMethod.Get)]

    procedure​​ PrintEmps(const​​ AContext: TEndpointContext;

    const​​ ARequest: TEndpointRequest; 

    const​​ AResponse: TEndpointResponse); 

  end;

요청 처리를 클래스 또는 컴포넌트로 위임

RAD 서버의 사용자 리소스에 발생한 요청을 필드로 지정한 다른 자원 모듈(클래스 / 컴포넌트)로 위임하는 기능이 추가되었습니다.

위임받는 클래스는 IEMSEndpointPublisher 인터페이스를 구현해야 합니다.

 

코드 예제:

type

  TEmpsProvider = class​​(TComponent, IEMSEndpointPublisher)

  private

    class var

      FArray: TJSONArray;

  private

    function​​ GetItemByID(ARequest: TEndpointRequest): Integer;

    class​​ constructor Create;

    class​​ destructor Destroy;

  public
    procedure​​ Get(const​​ AContext: TEndpointContext;

      const​​ ARequest: TEndpointRequest;

      const​​ AResponse: TEndpointResponse); overload​​;

    [ResourceSuffix('./{id}')]

    procedure​​ GetItem(const​​ AContext: TEndpointContext;

      const​​ ARequest: TEndpointRequest;

      const​​ AResponse: TEndpointResponse); overload​​;

    [ResourceSuffix('./{id}')]

    procedure​​ Put(const​​ AContext: TEndpointContext;

      const​​ ARequest: TEndpointRequest;

      const​​ AResponse: TEndpointResponse);

    procedure​​ Post(const​​ AContext: TEndpointContext;

      const​​ ARequest: TEndpointRequest;

      const​​ AResponse: TEndpointResponse);

    [ResourceSuffix('./{id}')]

    procedure​​ Delete(const​​ AContext: TEndpointContext;

      const​​ ARequest: TEndpointRequest; 

      const​​ AResponse: TEndpointResponse);

  end​​;

 

  [ResourceName('Test')]

  TTestResource = class​​(TDataModule)

  public

 

    Emps: TEmpsProvider;

    constructor​​ Create(AOwner: TComponent); override​​;

  end​​

 

위와 같이 구현 시 다음 요청은 Emps 객체인 TEmpsProvider의 메소드에 의해 다음과 같이 처리됩니다.

  • GET http://localhost/test/emps - TEmpsProvider.Get 메소드
  • GET http://localhost/test/emps/1 - TEmpsProvider.GetItem 메소드

JSON 처리를 위한 헬퍼 컴포넌트 추가

컴포넌트에 요청 처리를 위임하는 새로운 기능을 이용해 RAD 스튜디오 10.3 리오에서 JSON 처리를 단순화 하는 새로운 컴포넌트가 추가되었습니다.

  • TEMSFileResource : 경로 및 파일이름 속성에 지정된 파일로 요청 처리
  • TEMDDataSetResource : DataSet 속성에 설정된 데이터셋의 데이터를 JSON으로 처리, 페이징 파라메터 지원

코드 샘플:

 

 

[ResourceName('Notes')]

TNotesResource1 = class​​(TDataModule)

  FDConnection1: TFDConnection; // connects to SQLite DB with "notes" table

  FDQuery1: TFDQuery; // SELECT * FROM Notes

  [ResourceSuffix('list', '/')]

  [ResourceSuffix('get', '/{id}')]

  [ResourceSuffix('put', '/{id}')]

  [ResourceSuffix('post', '/')]

  [ResourceSuffix('delete', '/{id}')]

  EMSDBResource1: TEMSDataSetResource;

end​​;

// database resource
[ResourceSuffix('/')]
EMSDBResource1: TEMSDataSetResource;
[ResourceSuffix('/')]
[EndpointProduce('get', 'image/jpeg, image/png')]
EMSDBResource1: TEMSDataSetResource;
// file resource
[ResourceSuffix('/')]
[EndpointProduce('get', 'application/pdf')]
EMSFileResource1: TEMSFileResource;

 

RAD 서버의 기타 개선사항

  • RAD 서버의 성능이 간단한 작업 시 처리량이 10배 이상 향상되었습니다.

 

 

 

 

 

 

10.3 리오의 업데이트 버전들

 

 

번호 제목 글쓴이 날짜 조회 수
공지 [DelphiCon 요약] 코드사이트 로깅 실전 활용 기법 (Real-world CodeSite Logging Techniques) 관리자 2021.01.19 15414
공지 [UX Summit 요약] 오른쪽 클릭은 옳다 (Right Click is Right) 관리자 2020.11.16 13960
공지 [10.4 시드니] What's NEW! 신기능 자세히 보기 관리자 2020.05.27 16496
공지 RAD스튜디오(델파이,C++빌더) - 고객 사례 목록 관리자 2018.10.23 22048
공지 [데브기어 컨설팅] 모바일 앱 & 업그레이드 마이그레이션 [1] 관리자 2017.02.06 23267
공지 [전체 목록] 이 달의 기술자료 & 기술레터 관리자 2017.02.06 18921
공지 RAD스튜디오(델파이, C++빌더) - 시작하기 [1] 관리자 2015.06.30 39245
공지 RAD스튜디오(델파이,C++빌더) - 모바일 앱 개발 사례 (2020년 11월 업데이트 됨) 험프리 2014.01.16 174696
18 [10.3 리오] 델파이 언어의 새로운 변화: 인라인 변수 선언 관리자 2018.11.12 2670
17 [10.3 리오][업데이트 1] What's NEW! 신기능 자세히 보기 험프리 2019.02.18 1996
16 [10.3 리오] IDE가 현대적이고 깔끔하게 업데이트 되었습니다. 관리자 2018.11.14 1886
15 [10.3 리오][업데이트1] VCL, FMX용 새로운 스타일 15종 지원 관리자 2019.02.22 1354
14 [10.3 리오] 안드로이드 권한 요청 매커니즘 변경이 반영되었습니다. file 험프리 2018.12.06 1144
13 [10.3 리오] 안드로이드 Z-Order, 네이티브 컨트롤 관리자 2018.11.15 1049
12 [10.3 리오] C++17 지원으로 Clang 컴파일러가 더욱 강화되었습니다. file 관리자 2018.11.16 1014
11 [10.3.3][업데이트][핫픽스] RAD 스튜디오, 델파이, C++빌더 10.3.3 패치 목록 [1] 험프리 2019.12.26 892
10 [업데이트][10.3.2][패치] 업데이트 및 패치 정보 [5] 험프리 2019.08.23 872
9 [10.3 리오] High DPI가 적용된 이미지 리스트로 다양한 해상도의 이미지를 지원할 수 있습니다. 험프리 2018.12.05 767
8 [10.3 리오] 윈도우 스토어 연동, 최신 윈도우 API 업데이트 등 윈도우 10 지원이 강화되었습니다. file 험프리 2018.12.05 697
7 [업데이트][핫픽스][10.3] 2018년 12월 패치 험프리 2018.12.17 657
6 [10.3 리오][업데이트1] 새로운 IDE 생산성 도구: 북마크 & 탐색기 관리자 2019.02.22 624
5 [10.3 리오] 기타 컴파일러, 데이터, RTL 개선사항 험프리 2018.12.06 561
4 [10.3 리오][업데이트1] 재설계한 RAD서버 콘솔 UI : API 분석 용이 & Ext JS로의 마이그레이션 지원 관리자 2019.02.22 496
» [10.3 리오] RAD 서버 엔드 포인트 연동이 더욱 쉽고 다양해 졌습니다. 험프리 2018.12.06 453
2 [10.3 리오][업데이트1] iOS 12, iPhone X 시리즈 디바이스들 지원 관리자 2019.02.22 434
1 [10.3 리오] 리눅스 컴파일러에 non-ARC 메모리 모델이 적용됩니다. 험프리 2018.12.04 384