Службы данных WCF - WCF Data Services

Службы данных WCF
Оригинальный автор (ы)Microsoft
изначальный выпуск11 августа 2008 г.; 12 лет назад (2008-08-11)
Стабильный выпуск
5.6.0
Операционная системаМайкрософт Виндоус, Linux, macOS
Интернет сайтmsdn.microsoft.com/ en-us/библиотека/ cc907912.aspx

WCF Службы данных (ранее Службы данных ADO.NET,[1] кодовое название "Астория"[2]) является платформой для чего Microsoft звонки Службы данных. На самом деле это комбинация среды выполнения и веб-сервис через которые предоставляются услуги. Он также включает Набор инструментов Data Services что позволяет создавать Astoria Data Services изнутри ASP.NET сам. О проекте Astoria было объявлено на СМЕШИВАНИЕ 2007, а первая предварительная версия для разработчиков была доступна 30 апреля 2007 года. ОСАГО был доступен как часть ASP.NET 3.5 Предварительный просмотр расширений. Финальная версия была выпущена в рамках Service Pack 1 из .NET Framework 3.5 11 августа 2008 г. Об изменении названия с ADO.NET Data Services на WCF Data Services было объявлено на конференции 2009 г. PDC.

Обзор

WCF Data Services предоставляет данные, представленные как Модель данных сущности (EDM) через веб-сервисы, доступ к которым осуществляется через HTTP. К данным можно обращаться с помощью ОТДЫХ -подобно URI. Служба данных при доступе через метод HTTP GET с таким URI вернет данные. Веб-сервис можно настроить для возврата данных в любом виде XML, JSON или же RDF + XML. В первоначальном выпуске такие форматы, как RSS и АТОМ не поддерживаются, хотя могут появиться в будущем. Кроме того, с помощью других методов HTTP, таких как PUT, POST или DELETE, данные также можно обновлять. POST может использоваться для создания новых сущностей, PUT для обновления сущности и DELETE для удаления сущности.

Описание

Windows Communication Foundation (WCF) приходит на помощь, когда мы оказываемся не в состоянии достичь того, чего мы хотим достичь с помощью веб-служб, то есть поддержки других протоколов и даже дуплексной связи. С помощью WCF мы можем определить нашу службу один раз, а затем настроить ее таким образом, чтобы ее можно было использовать через HTTP, TCP, IPC и даже очереди сообщений. Мы можем использовать веб-службы, используя сценарии на стороне сервера (ASP.NET), нотации объектов JavaScript (JSON) и даже REST (передача репрезентативного состояния).

Понимание основ

Когда мы говорим, что службу WCF можно использовать для связи с использованием разных протоколов и из разных типов приложений, нам нужно будет понять, как мы можем этого добиться. Если мы хотим использовать службу WCF из приложения, у нас есть три основных вопроса:

1.Где находится служба WCF с точки зрения клиента?2.Как клиент может получить доступ к услуге, т. Е. Протоколам и форматам сообщений?3.Какую функциональность предоставляет услуга клиентам?

Как только мы получим ответ на эти три вопроса, создание и использование службы WCF станет для нас намного проще. Служба WCF имеет концепцию конечных точек. Служба WCF предоставляет конечные точки, которые клиентские приложения могут использовать для связи со службой WCF. Ответ на эти вопросы - это то, что известно как азбука служб WCF и фактически является основными компонентами службы WCF. Итак, давайте рассмотрим каждый вопрос по очереди.

Адрес: Как и веб-служба, служба WCF также предоставляет URI, который может использоваться клиентами для доступа к службе WCF. Этот URI называется адресом службы WCF. Это решит первую проблему «где разместить службу WCF?» для нас.

Привязка: Как только мы сможем найти службу WCF, следует подумать о том, как взаимодействовать со службой (с точки зрения протокола). Привязка определяет, как служба WCF обрабатывает обмен данными. Он также может определять другие параметры связи, такие как кодирование сообщений и т. Д. Это решит вторую проблему «как взаимодействовать со службой WCF?» для нас.

Договор: Остается только один вопрос - о функциональных возможностях, которые предоставляет служба WCF. Контракт определяет общедоступные данные и интерфейсы, которые служба WCF предоставляет клиентам.

URI, представляющие данные, будут содержать физическое расположение службы, а также имя службы. Также потребуется указать EDM Entity-Set или конкретный экземпляр объекта, как в соответственно

http: //dataserver/service.svc/MusicCollection

или же

http: //dataserver/service.svc/MusicCollection [SomeArtist]

В первом будут перечислены все сущности в Коллекция установлен, тогда как последний будет перечислять только для объекта, который индексируется SomeArtist.

URI также могут указывать обход отношения в модели данных сущности. Например,

http: //dataserver/service.svc/MusicCollection [SomeSong] / Жанр

пересекает отношения Жанр (на языке SQL объединяется с Жанр table) и получает все экземпляры Жанр которые связаны с сущностью SomeSong. Простые предикаты также могут быть указаны в URI, например

http: //dataserver/service.svc/MusicCollection [SomeArtist] / ReleaseDate [год, эквивалент 2006]

будет получать элементы, проиндексированные SomeArtist и имел свои релиз в 2006. Информация о фильтрации и разделах также может быть закодирована в URL как

http: //dataserver/service.svc/MusicCollection? $ orderby = ReleaseDate & $ skip = 100 & $ top = 50

Хотя наличие пропускать и верх Ключевые слова указывают на поддержку пейджинга, в Data Services версии 1 нет метода определения количества доступных записей и, следовательно, невозможно определить, сколько страниц может быть. В OData 2.0 добавляет поддержку $ count сегмент пути (чтобы вернуть только количество объектов) и $ inlineCount (чтобы получить страницу сущностей и общее количество без отдельного обхода ...).[3]

Рекомендации

  1. ^ «Упрощение нашей многоуровневой платформы разработки: объединение трех вещей в одну». Блог группы разработчиков служб данных ADO.NET. 2009-11-17. Получено 2009-12-17.
  2. ^ "Выпущена CTP служб данных ADO.NET!". Получено 2007-11-12.
  3. ^ Архивные документы. «Что нового в WCF Data Services 5.0». docs.Microsoft.com. Получено 9 марта, 2019.

внешняя ссылка