Руководство. Отправка уведомлений в приложения универсальная платформа Windows с помощью Центров уведомлений Azure
В этом руководстве создается Центр уведомлений Azure для отправки push-уведомлений в приложение универсальной платформы Windows (UWP). Вы создадите пустое приложение Магазина Windows, получающее push-уведомления с помощью службы push-уведомлений Windows (WNS). Затем вы сможете рассылать push-уведомления на все устройства, на которых запущено ваше приложение, с помощью центра уведомлений.
Примечание.
Полный код для работы с этим руководством можно найти на портале GitHub.
Вам необходимо сделать следующее:
- Создание приложения в Магазине Windows
- Создание центра уведомлений
- Создание примера приложения Windows
- Отправка проверочных уведомлений
Необходимые компоненты
- Подписка Azure. Если у вас еще нет подписки Azure, создайте бесплатную учетную запись Azure, прежде чем начинать работу.
- Microsoft Visual Studio 2017 или более поздней версии. В примере для этого учебника используется Visual Studio 2019.
- Установленные средства разработки приложений универсальной платформы Windows
- Активная учетная запись Магазина Windows.
- Убедитесь, что параметр Получать уведомления от приложений и других отправителей включен.
- Откройте окно Параметры на компьютере.
- Выберите элемент Система.
- Выберите Notifications & actions (Уведомления и действия) в меню слева.
- Убедитесь, что параметр Получать уведомления от приложений и других отправителей включен. Если он не включен, включите его.
Изучение этого руководства является необходимым условием для работы со всеми остальными руководствами, посвященными Центрам уведомлений для приложений универсальной платформы Windows.
Создание приложения в Магазине Windows
Примечание.
Служба push-уведомлений (Майкрософт) (MPNS) устарела и больше не поддерживается.
Чтобы отправлять push-уведомления в приложения UWP, необходимо связать приложение с Магазином Windows. Затем необходимо настроить интеграцию концентратора уведомлений с WNS.
Перейдите в Центр разработки для Windows, войдите с помощью учетной записи Майкрософт, а затем выберите Создать приложение.
Введите имя приложения и выберите Зарезервировать имя продукта. Будет создана регистрация в Магазине Windows для вашего приложения.
Разверните узел Управление продуктом и выберите пункт Удостоверение продукта. Запишите Идентификатор безопасности пакета, Пакет, удостоверение, имя, Пакет/удостоверение/издатель, а также значения Пакет/свойство/отображаемое имя издателя.
В разделе Управление продуктом выберите WNS/MPNS, а затем выберите Портал регистрации приложений. Войдите в систему с помощью учетной записи Майкрософт. Страница регистрации приложений откроется в новой вкладке.
В разделе Essentialsвыберите Учетные данные клиента: добавить сертификат или секрет.
На странице "Сертификаты и секреты" в разделе секретов клиента выберите новый секрет клиента. Создав секрет клиента (также называемого секретом приложения), запишите его, прежде чем покинуть страницу.
Предупреждение
Вы можете только просматривать значения секрета клиента (секрета приложения) сразу после их создания. Обязательно сохраните секрет, прежде чем покинуть страницу.
Предупреждение
Секрет приложения и ИД безопасности пакета — это важные учетные данные для безопасного доступа. Не сообщайте никому эти значения и не распространяйте их вместе со своим приложением.
Создание центра уведомлений
Войдите на портал Azure.
В меню слева выберите Все службы.
Введите центры уведомлений в текстовом поле " Службы фильтрации". Щелкните значок звездочки рядом с именем службы, чтобы добавить ее в раздел Избранное в меню слева. Выберите Центры уведомлений.
На странице Центры уведомлений выберите Добавить на панели инструментов.
На вкладке Основные сведения на странице Центр уведомлений выполните следующие действия:
В поле Подписка выберите имя подписки Azure, которую вы хотите использовать, а затем выберите существующую группу ресурсов или создайте новую.
Введите уникальное имя нового пространства имен в разделе Сведения о пространстве имен.
Пространство имен содержит один или несколько концентраторов уведомлений, поэтому укажите имя концентратора в разделе Сведения о Центре уведомлений.
Выберите значение в раскрывающемся списке Расположение. Это значение определяет расположение, в котором создается центр.
Просмотрите параметр Зоны доступности. Если выбран регион с зонами доступности, по умолчанию выбрано поле проверка. Зоны доступности является платной функцией, поэтому дополнительная плата добавляется на ваш уровень.
Выберите вариант аварийного восстановления: Нет, парный регион восстановления или гибкий регион восстановления. При выборе парного региона восстановления отображается регион отработки отказа. Если выбрать гибкий регион восстановления, используйте раскрывающийся список регионов восстановления.
Нажмите кнопку создания.
После завершения развертывания выберите "Перейти к ресурсу".
Настройка параметров WNS для центра
Выберите Windows (WNS) в категории Параметры уведомлений.
Введите значения для параметров SID пакета (например, "ms-app://
<Your Package SID>
") и Ключ безопасности (Секрет приложения), которые вы записали в предыдущем разделе.Нажмите кнопку Сохранить на панели инструментов.
Теперь концентратор уведомлений настроен для работы с WNS. А у вас есть строки подключения для регистрации приложения и отправки уведомлений.
Создание примера приложения Windows
В Visual Studio откройте меню Файл и выберите Создать, а затем — Проект.
В диалоговом окне Создать проект сделайте следующее:
В поле поиска в верхней части страницы введите Windows Universal.
В результатах поиска выберите Blank App (Universal Windows) (Пустое приложение (универсальные приложения Windows)), а затем выберите Далее.
В диалоговом окне Настроить новый проект введите имя проектаи расположение для файлов проекта.
Нажмите кнопку создания.
Примите значения по умолчанию для целевой и минимальной версий платформы и нажмите кнопку ОК.
В обозревателе решений щелкните правой кнопкой мыши проект приложения для Магазина Windows, выберите Опубликовать, а затем — Связать приложение с Магазином. Откроется мастер Свяжите свое приложение с Магазином Windows .
В мастере войдите с помощью учетной записи Майкрософт.
Выберите приложение, зарегистрированное на шаге 2, нажмите кнопку Далее, а затем выберите Связать. После этого необходимые регистрационные данные Магазина Windows будут добавлены в манифест приложения.
В Visual Studio щелкните решение правой кнопкой мыши, а затем выберите пункт Управление пакетами NuGet. Откроется окно Управление пакетами NuGet.
В поле поиска введите WindowsAzure.Messaging.Managed, затем выберите установить и примите условия использования.
Это действие предназначено для скачивания и установки библиотеки Центров уведомлений Azure для Windows, а также добавления ссылки на нее с помощью пакета NuGet Microsoft.Azure.Notification Hubs.
Откройте файл проекта
App.xaml.cs
и добавьте следующие операторы:using Windows.Networking.PushNotifications; using Microsoft.WindowsAzure.Messaging; using Windows.UI.Popups;
В файле проекта
App.xaml.cs
найдите классApp
и добавьте следующее определение методаInitNotificationsAsync
. Замените<your hub name>
именем центра уведомлений, созданным на портале Azure, а<Your DefaultListenSharedAccessSignature connection string>
— строкой подключенияDefaultListenSharedAccessSignature
, полученной на странице Политики доступа в центре уведомлений:private async void InitNotificationsAsync() { var channel = await PushNotificationChannelManager.CreatePushNotificationChannelForApplicationAsync(); var hub = new NotificationHub("<your hub name>", "<Your DefaultListenSharedAccessSignature connection string>"); var result = await hub.RegisterNativeAsync(channel.Uri); // Displays the registration ID so you know it was successful if (result.RegistrationId != null) { var dialog = new MessageDialog("Registration successful: " + result.RegistrationId); dialog.Commands.Add(new UICommand("OK")); await dialog.ShowAsync(); } }
Этот код получает универсальный идентификатор ресурса (URI) канала для приложения из WNS, а затем регистрирует этот идентификатор в вашем центре уведомлений.
Примечание.
Замените заполнитель
hub name
именем концентратора уведомлений, которое отображается на портале Azure. Кроме того, замените заполнитель строки подключения строкой подключенияDefaultListenSharedAccessSignature
, полученной на странице Политики доступа концентратора уведомлений при работе с предыдущим разделом.В верхней части обработчика событий
OnLaunched
в файлеApp.xaml.cs
добавьте следующий вызов к новому методуInitNotificationsAsync
:InitNotificationsAsync();
Это обеспечит регистрацию URI канала в центре уведомлений при каждом запуске приложения.
Щелкните
Package.appxmanifest
правой кнопкой мыши и выберите Посмотреть код (F7). Укажите<Identity .../>
и замените значение Имя значением Пакет/удостоверение/имя и замените значение Издатель значением Пакет/удостоверение/издатель из созданного ранее приложения.Чтобы запустить приложение, нажмите на клавиатуре клавишу F5. Отобразится диалоговое окно, содержащее ключ регистрации. Чтобы закрыть диалоговое окно, нажмите кнопкуОК.
Теперь приложение готово к получению всплывающих уведомлений.
Отправка проверочных уведомлений
Чтобы проверить получение уведомлений в приложении, отправьте уведомления на портале Azure.
На портале Azure перейдите на вкладку "Обзор" и выберите Тестовая отправка на панели инструментов.
В окне Тестовая отправка сделайте следующее:
В поле Платформы выберите значение Windows.
В поле Тип уведомления выберите значение Всплывающее уведомление.
Выберите Отправить.
Просмотреть результат операции отправки можно в списке Результат в нижней части окна. Также появится оповещение.
Вы увидите оповещение Тестовое сообщение на своем рабочем столе.
Следующие шаги
Вы настроили рассылку уведомлений на все устройства Windows через портал или консольное приложение. Чтобы узнать, как отправлять push-уведомления на конкретные устройства, перейдите к следующему руководству: