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 21585
공지 [UX Summit 요약] 오른쪽 클릭은 옳다 (Right Click is Right) 관리자 2020.11.16 20216
공지 [10.4 시드니] What's NEW! 신기능 자세히 보기 관리자 2020.05.27 22270
공지 RAD스튜디오(델파이,C++빌더) - 고객 사례 목록 관리자 2018.10.23 28018
공지 [데브기어 컨설팅] 모바일 앱 & 업그레이드 마이그레이션 [1] 관리자 2017.02.06 29304
공지 [전체 목록] 이 달의 기술자료 & 기술레터 관리자 2017.02.06 24630
공지 RAD스튜디오(델파이, C++빌더) - 시작하기 [1] 관리자 2015.06.30 45557
공지 RAD스튜디오(델파이,C++빌더) - 모바일 앱 개발 사례 (2020년 11월 업데이트 됨) 험프리 2014.01.16 181079
70 이 달의 기술자료 - 2021년 02월 file 험프리 2021.01.26 548
69 [10.3 리오][업데이트 2] IDE 향상된 기능들 [4] 관리자 2019.08.12 547
68 이 달의 기술자료 - 2019년 03월 file 험프리 2019.02.27 547
67 이 달의 기술자료 - 2018년 07월 file 험프리 2018.06.28 547
66 VCL 앱, 윈도우 10용으로 현대화하기 관리자 2019.09.25 546
65 이 달의 기술자료 - 2018년 04월 file 험프리 2018.03.30 545
64 이 달의 기술자료 - 2018년 06월 file 험프리 2018.05.25 540
63 [10.4 시드니 신기능] 고해상도 DPI용 VCL 콘트롤(들) 관리자 2020.06.04 538
62 프로그래밍 언어 인기도 측정의 문제점 file 김원경 2020.03.27 537
61 iOS 배포 시 에러 해결방법: Cant' start debugserver on device - device support image was not mounted 관리자 2019.07.17 537
60 이 달의 기술자료 - 2018년 11월 file 험프리 2018.10.26 531
59 [업데이트][핫픽스][10.2.2] 웰컴 페이지 패치 험프리 2018.01.25 520
58 2020 년 8 월 GM 업데이트 관리자 2020.08.24 515
57 [업데이트][핫픽스][10 시애틀] 10 시애틀 iOS 9.2 C++ 핫픽스 험프리 2015.12.28 512
56 [10.4 시드니][업데이트 2] TCONTROLLIST – 새로운 VCL 컨트롤 관리자 2021.03.02 511
» [10.3 리오] RAD 서버 엔드 포인트 연동이 더욱 쉽고 다양해 졌습니다. 험프리 2018.12.06 511
54 [업데이트][핫픽스][10.2.1] 상속된 VCL 폼의 디스플레이 배율 미적용 버그 해소 file 험프리 2017.09.11 510
53 [10.3 리오][업데이트 3] 향상된 IDE 기능들 file 관리자 2019.12.03 506
52 [10.4.1 패치] 애플(APPLE) 플랫폼 지원 관리자 2020.11.30 504
51 이 달의 기술자료 - 2020년 07월 험프리 2020.06.25 501