Tutorial: Enviar notificações por push para aplicativos Xamarin.Android usando os Hubs de Notificação
Visão geral
Observação
Para obter informações sobre as etapas de substituição e migração do Firebase Cloud Messaging, confira Migração do Google Firebase Cloud Messaging.
Este tutorial mostra como usar os Hubs de Notificação do Azure para enviar notificações por push para um aplicativo Xamarin.Android. Você cria um aplicativo Xamarin.Android em branco que recebe notificações por push usando o FCM (Firebase Cloud Messaging). Você usa seu hub de notificação para transmitir notificações por push a todos os dispositivos que executam seu aplicativo. O código concluído está disponível na amostra do aplicativo NotificationHubs.
Neste tutorial, você deve executar as seguintes etapas:
- Criar um projeto de Firebase e habilitar Firebase Cloud Messaging
- Criar um hub de notificação
- Criar um aplicativo Xamarin.Android e conectar-se ao hub de notificação
- Enviar notificações por push de teste do portal do Azure
Pré-requisitos
- Assinatura do Azure. Caso você não tenha uma assinatura do Azure, crie uma conta gratuita do Azure antes de começar.
- Visual Studio com Xamarin no Windows ou Visual Studio para Mac no OS X.
- Conta ativa do Google
Criar um projeto de Firebase e habilitar Firebase Cloud Messaging
Faça logon no console do Firebase. Crie um novo projeto do Firebase se você ainda não tiver um.
Depois de criar seu projeto, selecione Adicionar Firebase ao seu aplicativo Android.
Siga estas etapas na página Adicionar Firebase ao seu aplicativo Android:
Para o nome do pacote do Android, insira um nome para o pacote. Por exemplo:
tutorials.tutorial1.xamarinfcmapp
.Selecione Registrar aplicativo.
Selecione Baixar google-services.json. Em seguida, salve o arquivo na pasta do projeto e selecione Avançar. Se ainda não criou o projeto do Visual Studio, poderá realizar essa etapa depois de criar o projeto.
Selecione Avançar.
Selecione Ignorar esta etapa.
No console do Firebase, selecione a engrenagem para seu projeto. Em seguida, selecione Configurações do Projeto.
Se você ainda não baixou o arquivo google-services.json, é possível fazer isso nesta página.
Mude para a guia Mensagens de Nuvem na parte superior. Copie e salve a Chave do servidor para uso posterior. Você usará esse valor para configurar o hub de notificação.
Criar um hub de notificação
Entre no portal do Azure.
Selecione Todos os serviços no menu esquerdo.
Digite Hubs de Notificação na caixa de texto Filtrar serviços. Selecione o ícone de estrela ao lado do nome do serviço para adicionar o serviço na seção FAVORITOS no menu à esquerda. Selecione Hubs de Notificação.
Na página Hubs de Notificações, selecione Criar na barra de ferramentas.
Na guia Informações Básicas da página Hub de Notificações, execute as seguintes etapas:
Em Assinatura, selecione o nome da assinatura do Azure que deseja usar e escolha um grupo de recursos existente ou crie um.
Insira um nome exclusivo para o novo namespace em Detalhes do Namespace.
Um namespace contém um ou mais hubs de notificações. Portanto, digite um nome para o hub em Detalhes do Hub de Notificações.
Selecione um valor da caixa de listagem suspensa Local. Esse valor especifica a localização na qual você deseja criar o hub.
Revise a opção Zonas de Disponibilidade. Se você escolher uma região que tenha zonas de disponibilidade, a caixa de seleção será marcada por padrão. As Zonas de Disponibilidade são um recurso pago, portanto, um valor adicional será acrescentado à sua camada de serviço.
Escolha uma opção de Recuperação de desastre: Nenhuma, Região de recuperação emparelhada ou Região de recuperação flexível. Se você escolher Região de recuperação emparelhada, a região de failover será exibida. Se você selecionar Região de recuperação flexível, use a lista suspensa para escolher entre uma lista de regiões de recuperação.
Selecione Criar.
Após a conclusão da implantação, selecione Ir para o recurso.
Configurar as definições do GCM/FCM para o hub de notificação
Selecione Google (GCM/FCM) na seção Configurações no menu à esquerda.
Insira a chave do servidor que você anotou do Google Firebase Console.
Selecione Salvar na barra de ferramentas.
Seu hub de notificação está configurado para funcionar com o FCM e você tem as cadeias de conexão para registrar o aplicativo para receber notificações e enviar notificações por push.
Criar um aplicativo Xamarin.Android e conectá-lo ao hub de notificação
Criar um projeto do Visual Studio e adicionar pacotes NuGet
Observação
As etapas documentadas neste tutorial são para o Visual Studio 2017.
No Visual Studio, abra o menu Arquivo, selecione Novo e, em seguida, Projeto. Na janela Novo Projeto, execute estas etapas:
Expanda Instalado, Visual C# e clique em Android.
Selecione aplicativo Android (Xamarin) na lista.
Insira um nome para o projeto.
Selecione um local para o projeto.
Selecione OK
Na caixa de diálogo Novo aplicativo Android, selecione Aplicativo em branco e selecione OK.
Na janela do Gerenciador de Soluções, expanda Propriedadese clique em AndroidManifest.xml. Atualize o nome do pacote para corresponder ao nome do pacote inserido ao adicionar Firebase Cloud Messaging ao seu projeto no Google Firebase Console.
Defina a versão de destino do Android para o projeto como Android 10.0 seguindo estas etapas:
- Clique com o botão direito do mouse no projeto e selecione Propriedades.
- Para o campo Compilar usando a versão do Android: (estrutura de destino) , selecione Android 10.0.
- Selecione Sim na caixa de mensagem para continuar com a alteração da estrutura de destino.
Adicione os pacotes NuGet necessários ao projeto seguindo estas etapas:
Clique o botão direito do mouse no projeto e selecione Gerenciar Pacotes NuGet... .
Alterne para a guia Instalado, selecione Xamarin.Android.Support.Design e selecione Atualizar no painel direito para atualizar o pacote para a versão mais recente.
Alterne para a guia Procurar. Pesquise por Xamarin.GooglePlayServices.Base. Selecione Xamarin.GooglePlayServices.Base na lista de resultados. Em seguida, selecione Instalar.
Na janela do Gerenciador de Pacotes do NuGet, pesquise por Xamarin.Firebase.Messaging. Selecione Xamarin.Firebase.Messaging na lista de resultados. Em seguida, selecione Instalar.
Agora, pesquise por Xamarin.Azure.NotificationHubs.Android. Selecione Xamarin.Azure.NotificationHubs.Android na lista de resultados. Em seguida, selecione Instalar.
Adicione o arquivo JSON de Serviços do Google
Copie o arquivo
google-services.json
que você baixou do Google Firebase Console para a pasta do projeto.Adicione
google-services.json
ao projeto.Selecione
google-services.json
na janela Gerenciador de Soluções.No painel Propriedades, defina a ação de compilação como GoogleServicesJson. Se você não vir GoogleServicesJson, feche o Visual Studio, reinicialize-o, reabra o projeto e tente novamente.
Configurar hubs de notificação em seu projeto
Registrando com o Firebase Cloud Messaging
Se você estiver fazendo a migração do Google Cloud Messaging para o Firebase, o arquivo
AndroidManifest.xml
do projeto poderá conter uma configuração desatualizada do GCM, o que poderá causar a duplicação de notificação. Edite o arquivo e remova as seguintes linhas dentro da seção<application>
, se presente:<receiver android:name="com.google.firebase.iid.FirebaseInstanceIdInternalReceiver" android:exported="false" /> <receiver android:name="com.google.firebase.iid.FirebaseInstanceIdReceiver" android:exported="true" android:permission="com.google.android.c2dm.permission.SEND"> <intent-filter> <action android:name="com.google.android.c2dm.intent.RECEIVE" /> <action android:name="com.google.android.c2dm.intent.REGISTRATION" /> <category android:name="${applicationId}" /> </intent-filter> </receiver>
Adicione as seguintes instruções antes do elemento do aplicativo.
<uses-permission android:name="android.permission.INTERNET" /> <uses-permission android:name="com.google.android.c2dm.permission.RECEIVE" /> <uses-permission android:name="android.permission.WAKE_LOCK" /> <uses-permission android:name="android.permission.GET_ACCOUNTS"/>
Colete as informações a seguir para o aplicativo Android e o hub de notificação:
- Escutar cadeia de conexão: no painel, no Azure portal, escolha Exibir cadeias de conexão. Copie a cadeia de conexão
DefaultListenSharedAccessSignature
para esse valor. - Nome do hub: nome do seu hub no Azure portal. Por exemplo, mynotificationhub2.
- Escutar cadeia de conexão: no painel, no Azure portal, escolha Exibir cadeias de conexão. Copie a cadeia de conexão
Na janela Gerenciador de Soluções, clique com o botão direito do mouse no projeto, selecione Adicionar e, em seguida, Classe.
Crie uma classe
Constants.cs
para seu projeto Xamarin e defina os valores de constantes a seguir na classe. Substitua os espaços reservados pelos seus valores.public static class Constants { public const string ListenConnectionString = "<Listen connection string>"; public const string NotificationHubName = "<hub name>"; }
Adicione o seguinte usando as instruções para
MainActivity.cs
:using WindowsAzure.Messaging.NotificationHubs;
Adicione as seguintes propriedades à classe MainActivity:
internal static readonly string CHANNEL_ID = "my_notification_channel";
No
MainActivity.cs
, adicione o seguinte código aOnCreate
apósbase.OnCreate(savedInstanceState)
:// Listen for push notifications NotificationHub.SetListener(new AzureListener()); // Start the SDK NotificationHub.Start(this.Application, HubName, ConnectionString);
Adicione uma classe denominada
AzureListener
ao projeto.Adicione o seguinte usando as instruções para
AzureListener.cs
.using Android.Content; using WindowsAzure.Messaging.NotificationHubs;
Adicione o código acima da declaração de classe e faça com que a classe herde de
Java.Lang.Object
e implemente oINotificationListener
:public class AzureListener : Java.Lang.Object, INotificationListener
Adicione o código a seguir à classe
AzureListener
para processar as mensagens recebidas.public void OnPushNotificationReceived(Context context, INotificationMessage message) { var intent = new Intent(this, typeof(MainActivity)); intent.AddFlags(ActivityFlags.ClearTop); var pendingIntent = PendingIntent.GetActivity(this, 0, intent, PendingIntentFlags.OneShot); var notificationBuilder = new NotificationCompat.Builder(this, MainActivity.CHANNEL_ID); notificationBuilder.SetContentTitle(message.Title) .SetSmallIcon(Resource.Drawable.ic_launcher) .SetContentText(message.Body) .SetAutoCancel(true) .SetShowWhen(false) .SetContentIntent(pendingIntent); var notificationManager = NotificationManager.FromContext(this); notificationManager.Notify(0, notificationBuilder.Build()); }
Compile o seu novo projeto.
Executar aplicativo no dispositivo ou emulador carregado
Enviar notificação por push de teste do portal do Azure
Você pode testar o recebimento de notificações no aplicativo com a opção Envio de Teste no Azure portal. Isso envia uma notificação por push de teste para seu dispositivo.
As notificações por push são geralmente enviadas em um serviço back-end, como Serviços Móveis ou ASP.NET, por meio de uma biblioteca compatível. Se uma biblioteca não estiver disponível para o back-end, você também poderá usar a API REST diretamente para enviar mensagens de notificação.
Próximas etapas
Neste tutorial, você envia notificações de transmissão para todos os seus dispositivos Android registrados com o back-end. Para saber como enviar notificações por push para dispositivos Android específicos, vá para o tutorial a seguir: