Симон Робинсон - C# для профессионалов. Том II
- Название:C# для профессионалов. Том II
- Автор:
- Жанр:
- Издательство:Лори
- Год:2003
- Город:Москва
- ISBN:5-85582-187-0
- Рейтинг:
- Избранное:Добавить в избранное
-
Отзывы:
-
Ваша оценка:
Симон Робинсон - C# для профессионалов. Том II краткое содержание
Платформа .NET предлагает новую среду, в которой можно разрабатывать практически любое приложение, действующее под управлением Windows, а язык C# — новый язык программирования, созданный специально для работы с .NET.
В этой книге представлены все основные концепции языка C# и платформы .NET. Полностью описывается синтаксис C#, приводятся примеры построения различных типов приложений с использованием C# — создание приложений и служб Windows, приложений и служб WWW при помощи ASP.NET, а также элементов управления Windows и WWW Рассматриваются общие библиотеки классов .NET, в частности, доступ к данным с помощью ADO.NET и доступ к службе Active Directory с применением классов DirectoryServices.
Для кого предназначена эта книгаЭта книга предназначена для опытных разработчиков, возможно, имеющих опыт программирования на VB, C++ или Java, но не использовавших ранее в своей работе язык C# и платформу .NET. Программистам, применяющим современные технологии, книга даст полное представление о том, как писать программы на C# для платформы .NET.
Основные темы книги• Все особенности языка C#
• C# и объектно-ориентированное программирование
• Приложения и службы Windows
• Создание web-страниц и web-служб с помощью ASP NET
• Сборки .NET
• Доступ к данным при помощи ADO NET
• Создание распределённых приложений с помощью NET Remoting
• Интеграция с COM, COM+ и службой Active Directory
C# для профессионалов. Том II - читать онлайн бесплатно полную версию (весь текст целиком)
Интервал:
Закладка:
public static void Main(string[] args) {
TcpServerChannel tcpChannel = new TcpServerChannel(8086);
HttpServerChannel httpChannel = new HttpServerChannel (8085);
// ...
Класс канала должен реализовать интерфейс IChannel. Интерфейс IChannelимеет два свойства:
□ ChannelIName— только для чтения, которое возвращает имя канала. Имя канала зависит от типа, например, канал HTTP называется HTTP.
□ ChannelPriority— только для чтения с условием, что более одного канала используется для коммуникации между клиентом и сервером. Приоритет определяет порядок каналов. На клиенте канал с более высоким приоритетом выбирается первым для соединения с сервером.
В зависимости от того, является ли канал клиентским каналом или серверным каналом, реализуются дополнительные интерфейсы. Серверные версии каналов реализуют интерфейс IChannelReceiver, клиентские версии — интерфейс IChannelSender.
Классы HttpChannelи TcpChannelиспользуются как для клиентов, так и для серверов. Они реализуют IChannelSenderи IChannelReceiver. Эти интерфейсы являются производными из IChannel.
IChannelSenderклиентской стороны имеет в дополнение в IChannelединственный метод, называемый CreateMessageSink(), который возвращает объект, реализующий IMessageSink. Интерфейс IMessageSinkприменяется для размещения синхронных, а также асинхронных сообщений в канале. С помощью интерфейса серверной стороны IChannelReceiverканал можно перевести в режим прослушивания с помощью метода StartListening()и снова остановить с помощью метода StopListening(). Также имеется свойство для доступа к полученным данным.
Информацию о конфигурации обоих каналов получают с помощью свойств классов каналов ChannelName, ChannelPriorityи ChannelData. С помощью свойства ChannelDataполучают информацию об URI, который хранится в классе ChannelDataStore. В классе HttpChannelимеется также свойство Scheme. Ниже представлен вспомогательный метод ShowChannelProperties(), демонстрирующий эти данные.
protected static void ShowChannelProperties(IChannelReceiver channel) {
Console.WriteLine("Name; " + channel.ChannelName");
Console.WriteLine("Priority: " + channel.ChannelPriority);
if (channel is HttpChannel) {
HttpChannel httpChannel = channel as HttpChannel;
Console.WriteLine("Scheme: " + httpChannel.ChannelScheme);
}
ChannelDataStore data = (ChannelDataStore)channel.ChannelData;
foreach (string uri in data.ChannelUris) {
Console.WriteLine("URI: " + uri);
}
Console.WriteLine();
}
После создания каналов вызывается метод ShowChannelProperties():
TcpServerChannel tcpChannel = new TcpServerChannel(8086);
ShowChannelProperties(tcpChannel);
HttpServerChannel httpChannel = new HttpServerChannel(8085);
ShowChannelProperties(httpChannel);
С помощью каналов TCP и HTTP будет получена следующая информация:
Как можно видеть, именем по умолчанию для TcpServerChannelбудет tcp, а канал HTTP называется http. Оба канала имеют свойство по умолчанию, равное 1 (в конструкторах заданы порты 8085 и 8086). URI каналов показывает протокол, имя хоста (в данном случае CNagel) и номер порта.
Задание свойств канала
Можно задать все свойства канала в списке с помощью конструктора TcpServerChannel(IDictionary, IServerChannelSinkProvider). Класс ListDictionaryреализует IDictionary, поэтому свойства Name, Priorityи Portзадаются с помощью этого класса.
Для использования класса ListDictionaryнеобходимо объявить использование пространства имен System.Collections.Specialized. В дополнение к параметру IDictionaryпередается параметр IServerChannelSinkProvider, в данном случае SoapServerFormatterSinkProviderвместо BinaryServerFormatterSinkProvider, который используется по умолчанию для TCPServerChannel. Реализация по умолчанию класса SoapServerFormatterSinkProviderассоциирует класс SoapServerFormatterSinkс каналом, применяющим SoapFormatterдля преобразования данных передачи:
ListDictionary properties = new ListDictionary();
properties.Add("Name", "TCP Channel with a SOAP Formatter");
properties.Add("Priority", "20");
properties.Add("Port", "8086");
SoapServerFormatterSinkProvider sinkProvider =
new SoapServerFormatterSinkProvider();
TcpServerChannel tcpChannel =
new TcpServerChannel(properties.sinkProvider);
ShowChannelProperties(tcpChannel);
Вывод, который будет получен из запускаемого на сервере кода, показывает новые свойства канала TCP:
Подключаемость канала
Можно создать специальный канал для отправки сообщений с помощью транспортного протокола, отличного от HTTP или TCP, или расширить существующие каналы:
□ Посылающая часть должна реализовать интерфейс IChannelSender. Наиболее важным является метод CreateMessageSink(), где клиент посылает URL, с помощью него создается экземпляр соединения с сервером. Здесь должен быть создан приемник сообщений, затем он используется прокси для отправки сообщений в канал.
□ Получающая часть должна реализовать интерфейс IChannelReceiver. Необходимо запустить прослушивание с помощью свойства ChannelData, затем ожидать отдельного потока выполнения для получения данных от клиента. После демаршализации сообщения метод ChannelServices.SyncDispatchMessage()может использоваться для отправки сообщения объекту.
Форматтеры
.NET Framework предоставляет два класса форматтера:
□ System.Runtime.Serialization.Formatters.Binary.BinaryFormatter.
□ System.Runtime.Serialization.Formatters.Soap.SoapFormatter.
Форматтер ассоциируется с каналом из-за наличия объектов приемников форматтера и провайдеров источников форматтера.
Оба эти класса форматтера реализуют интерфейс System.Runtime.Remoting.Messaging.IRemotingFormatter, который определяет методы Serialize()и Deserialize()для передачи и приема данных из канала.
Форматтер является подключаемым. При создании класса собственного форматтера экземпляр должен ассоциироваться с используемым каналом. Это делается с помощью приемника форматтера и провайдера приемника форматтера. Как было показано ранее, провайдер источника форматтера, например SoapServerFormatterSinkProvider, может передаваться как аргумент при создании канала. Провайдер источника форматтера реализует для сервера интерфейс IServerChannelSinkProvider, а для клиента IClientChannelSinkProvider. Оба эти интерфейса определяют метод CreateSink(), возвращающий источник форматтера, — SoapServerFormatterSinkProviderдаст экземпляр класса SoapServerFormatterSink. На клиентской стороне имеется класс SoapClientFormatterSink, который использует в методах SyncProcessMessage()и AsyncProcessMessage()класс SoapFormatterдля сериализации сообщения. SoapServerFormatterSinkдесериализует сообщение снова с помощью SoapFormatter.
Все эти классы приемника и провайдера способны расширяться и заменяться собственными реализациями.
Читать дальшеИнтервал:
Закладка: