배포 아키텍처
배포 API는 네트워크에서 배포된 콘텐츠를 다양한 형식으로 작성할 수 있는 형식 중립적 프로그래밍 모델을 제공하기 위해 디자인되었습니다. 추상 데이터 모델은 다음 클래스로 구성됩니다.
이러한 클래스는 이름이 다른 경우도 일부 있지만 Atom 1.0 사양에 정의된 구문에 밀접하게 매핑됩니다.
WCF(Windows Communication Foundation)의 경우 배포 피드는 다른 형식의 서비스 작업으로 모델링되며, 여기서 반환 형식은 SyndicationFeedFormatter의 파생 클래스 중 하나입니다. 피드의 검색은 요청-회신 메시지 교환으로 모델링됩니다. 클라이언트는 서비스에 대한 요청 및 서비스 응답을 보냅니다. 요청 메시지는 원시 HTTP와 같은 인프라 프로토콜을 통해 설정되며, 응답 메시지에는 일반적으로 인식되는 배포 형식(RSS 2.0 또는 Atom 1.0)으로 구성되는 페이로드가 포함됩니다. 이러한 메시지 교환을 구현하는 서비스를 배포 서비스라고 합니다.
배포 서비스 계약은 SyndicationFeedFormatter 클래스의 인스턴스를 반환하는 작업 집합으로 구성됩니다. 다음 예제에서는 배포 서비스에 대한 인터페이스 선언을 보여 줍니다.
[ServiceContract]
[ServiceKnownType(typeof(Atom10FeedFormatter))]
[ServiceKnownType(typeof(Rss20FeedFormatter))]
public interface IBlog
{
[OperationContract]
[WebGet(UriTemplate="GetBlog?format={format}", BodyStyle=WebMessageBodyStyle.Bare)]
SyndicationFeedFormatter GetBlog(string format);
}
배포 지원은 피드를 서비스로 사용할 수 있도록 WebHttpBehavior와 함께 사용되는 WebHttpBinding 바인딩을 정의하는 WCF REST 프로그래밍 모델을 기반으로 빌드됩니다. WCF REST 프로그래밍 모델에 대한 자세한 내용은 WCF 웹 HTTP 프로그래밍 모델 개요를 참조하세요.
참고 항목
Atom 1.0 사양에서는 모든 날짜 구문에 소수 자릿수 초를 지정할 수 있습니다. WCF 구현을 직렬화 및 역직렬화할 때 소수 자릿수 초를 무시합니다.
개체 모델
배포의 개체 모델은 다음 표의 클래스 그룹으로 구성됩니다.
클래스 형식 지정:
클래스 | 설명 |
---|---|
Atom10FeedFormatter | SyndicationFeed 인스턴스를 Atom 1.0 형식으로 serialize하는 클래스입니다. |
Atom10FeedFormatter<TSyndicationFeed> | SyndicationFeed 파생 클래스를 Atom 1.0 형식으로 serialize하는 클래스입니다. |
Atom10ItemFormatter | SyndicationItem 인스턴스를 Atom 1.0 형식으로 serialize하는 클래스입니다. |
Atom10ItemFormatter<TSyndicationItem> | SyndicationItem 파생 클래스를 Atom 1.0 형식으로 serialize하는 클래스입니다. |
Rss20FeedFormatter | SyndicationFeed 인스턴스를 RSS 2.0 형식으로 serialize하는 클래스입니다. |
Rss20FeedFormatter<TSyndicationFeed> | SyndicationFeed 파생 클래스를 RSS 2.0 형식으로 serialize하는 클래스입니다. |
Rss20ItemFormatter | SyndicationItem 인스턴스를 RSS 2.0 형식으로 serialize하는 클래스입니다. |
Rss20ItemFormatter<TSyndicationItem> | SyndicationItem 파생 클래스를 RSS 2.0 형식으로 serialize하는 클래스입니다. |
개체 모델 클래스:
클래스 | 설명 |
---|---|
SyndicationCategory | 배포 피드의 범주를 나타내는 클래스입니다. |
SyndicationContent | 배포 콘텐츠를 나타내는 기본 클래스입니다. |
SyndicationElementExtension | 배포 요소 확장을 나타내는 클래스입니다. |
SyndicationElementExtensionCollection | SyndicationElementExtension 개체의 컬렉션입니다. |
SyndicationFeed | 최상위 수준 피드 개체를 나타내는 클래스입니다. |
SyndicationItem | 피드 항목을 나타내는 클래스입니다. |
SyndicationLink | 배포 피드 또는 항목 내에서 링크를 나타내는 클래스입니다. |
SyndicationPerson | Atom Person 구문을 나타내는 클래스입니다. |
SyndicationVersions | 지원되는 배포 프로토콜 버전을 나타내는 클래스입니다. |
TextSyndicationContent | 최종 사용자에게 표시되는 SyndicationItem 콘텐츠를 나타내는 클래스입니다. |
TextSyndicationContentKind | 지원되는 다른 형식의 텍스트 배포 콘텐츠를 나타내는 열거형입니다. |
UrlSyndicationContent | 다른 리소스에 대한 URL로 구성된 배포 콘텐츠를 나타내는 클래스입니다. |
XmlSyndicationContent | 브라우저에 표시되지 않는 배포 콘텐츠를 나타내는 클래스입니다. |
개체 모델의 핵심 데이터 추상화는 SyndicationFeed 및 SyndicationItem 클래스에 해당하는 Feed 및 Item입니다. Feed는 제목, 설명 및 만든 이와 같은 피드 수준의 일부 메타데이터, 알 수 없는 확장을 저장하는 위치 및 나머지 피드 정보 콘텐츠를 구성하는 항목 집합을 노출합니다. Item은 제목, 요약 및 게시 날짜와 같은 항목 수준의 일부 메타데이터, 알 수 없는 확장을 저장하는 위치 및 나머지 항목 정보 콘텐츠를 포함하는 콘텐츠 요소를 사용 가능하게 만듭니다. Atom 1.0 및 RSS 사양에 참조되어 있는 일반 데이터 구문을 나타내는 추가 클래스에서는 Feed 및 Item의 핵심 추상화를 지원합니다.
Feed 인스턴스에 포함되어 있는 정보는 다양한 XML 형식으로 변환할 수 있습니다. XML에서 변환하거나 XML로 변환하는 프로세스는 SyndicationFeedFormatter 클래스에서 관리합니다. 이 클래스는 추상 클래스입니다. 구체적인 구현은 Atom 1.0 및 RSS 2.0, Atom10FeedFormatter 및 Rss20FeedFormatter를 위해 제공됩니다. 파생 Feed 클래스를 사용하려면 Atom10FeedFormatter<TSyndicationFeed> 또는 Rss20FeedFormatter<TSyndicationFeed> 중 하나를 사용합니다. 그러면 파생 Feed 클래스를 지정할 수 있습니다. 파생 Item 클래스를 사용하려면 Atom10ItemFormatter<TSyndicationItem> 또는 Rss20ItemFormatter<TSyndicationItem> 중 하나를 사용합니다. 그러면 파생 Item 클래스를 지정할 수 있습니다. 타사에서는 SyndicationFeedFormatter의 자체 구현을 파생하여 다른 배포 형식을 지원할 수 있습니다.
확장성
- 배포 프로토콜의 주요 기능은 확장성입니다. Atom 1.0 및 RSS 2.0에서는 사양에 정의되지 않은 배포 피드에 특성 및 요소를 추가할 수 있습니다. WCF 배포 프로그래밍 모델에서는 사용자 지정 특성 및 확장에 사용할 수 있는 새 클래스 파생 및 자유로운 형식의 액세스라는 두 가지 방식을 제공합니다. 자세한 내용은 배포 확장성을 참조하세요.