Usando um assistente de codificação com IA?
Para instalação orientada por IA, use este prompt:
Passo 0. Configure o FCM no OneSignal (necessário para entregar push)
Você pode instalar e inicializar o SDK Android da OneSignal sem concluir este passo. No entanto, as notificações push não serão entregues até que as credenciais do Firebase Cloud Messaging (FCM) sejam configuradas no seu aplicativo OneSignal.Se sua empresa já possui uma conta OneSignal, solicite um convite com função de administrador para configurar o aplicativo. Caso contrário, cadastre-se para uma conta gratuita para começar.
Passos para configurar seu aplicativo OneSignal.
Passos para configurar seu aplicativo OneSignal.
Estes passos conectam seu aplicativo OneSignal ao Firebase Cloud Messaging (FCM). Você só precisa fazer isso uma vez por aplicativo.
- Faça login em https://onesignal.com e crie ou selecione seu App.
- Navegue até Settings > Push & In-App.
- Selecione Google Android (FCM) e clique em Continue para prosseguir pelo assistente de configuração.
- Insira os detalhes da sua Firebase Server Key ou Service Account.
- Continue pelo assistente de configuração para obter seu App ID. Ele será usado para inicializar o SDK.
Para instruções completas de configuração, consulte nosso guia de Configuração de push mobile.
Contrato de configuração e requisitos
Esta seção resume as ferramentas, versões e premissas usadas ao longo do guia.- Versão do SDK:
5.6.1+(mais recente: verifique os releases) - Instruções de configuração por IA:
https://raw.githubusercontent.com/OneSignal/sdk-ai-prompts/main/docs/android/ai-prompt.md - Repositório do SDK:
https://github.com/OneSignal/OneSignal-Android-SDK - Android Studio: Meerkat+ (2024.2.1+)
- API Android: 23+ mínimo (Android 6.0+), 31+ recomendado (Android 12+)
- Dispositivo/Emulador: Android 7.0+ com Google Play Services instalado
- Dependência obrigatória:
com.onesignal:OneSignal:[5.6.1, 5.6.99] - Classe Application: Necessária para inicialização correta do SDK
- Formato do App ID: UUID de 36 caracteres (exemplo:
12345678-1234-1234-1234-123456789012) — encontre em OneSignal Dashboard > Settings > Keys & IDs - Inicialização:
OneSignal.initWithContext(this, "YOUR_APP_ID") - Otimização de bateria: Pode afetar notificações em segundo plano
- Recomendado: Atribuir External ID via
OneSignal.login("user_id")para unificar usuários entre dispositivos
Passos de configuração do Android
Ao final dos passos abaixo, você terá:- O SDK da OneSignal instalado e inicializado no seu aplicativo Android
- A solicitação de permissão de notificações push funcionando corretamente em um dispositivo real
- Um push de teste e uma mensagem in-app entregues com sucesso
Se você pulou o Passo 0 (Configuração do FCM no OneSignal), ainda pode concluir a configuração do Android Studio abaixo. Conclua o Passo 0 antes de testar ou enviar notificações push.
Passo 1. Adicione o SDK da OneSignal
- No Android Studio, abra o arquivo
build.gradle.kts (Module: app)oubuild.gradle (Module: app) - Adicione o OneSignal à seção
dependencies:

- Sincronize o Gradle: Clique em Sync Now no banner que aparece ou vá em File > Sync Project with Gradle Files
Verifique se a sincronização do Gradle foi concluída com sucesso e sem conflitos de dependências.
Passo 2. Crie e configure a classe Application
A prática recomendada é inicializar o OneSignal no métodoonCreate da sua classe Application para garantir a configuração correta do SDK em todos os pontos de entrada.
Crie uma classe Application se você ainda não tiver uma:
- File > New > Kotlin Class/File (ou Java Class)
- Nome:
ApplicationClass(ou o nome de sua preferência)

YOUR_APP_ID pelo seu App ID real da OneSignal em Dashboard > Settings > Keys & IDs.

- Abra o
AndroidManifest.xmldo seu aplicativo - Na tag
<application>, adicioneandroid:name=".ApplicationClass"(substitua.ApplicationClasspelo nome real da sua classe, caso tenha definido um nome diferente).
AndroidManifest.xml

Verifique se o aplicativo compila e executa sem erros.
Passo 3. Configure os ícones de notificação padrão (recomendado)
Personalize os ícones de notificação para combinar com a identidade visual do seu aplicativo. Este passo é opcional, mas recomendado para uma aparência profissional.Passo 4. Teste a integração
Verifique a criação da Subscription:- Inicie o aplicativo no dispositivo ou emulador com Google Play Services
- Verifique no Dashboard > Audience > Subscriptions — o status mostra “Never Subscribed”
- Aceite o prompt de permissão quando ele aparecer
- Atualize o dashboard — o status muda para “Subscribed”



Você criou com sucesso uma Subscription mobile.
As subscriptions mobile são criadas quando os usuários abrem seu aplicativo pela primeira vez em um dispositivo ou se desinstalam e reinstalam o aplicativo no mesmo dispositivo.
Crie uma Subscription de teste e um segmento
- Clique em ⋮ ao lado da Subscription > Add to Test Subscriptions > dê um nome
- Vá para Audience > Segments > New Segment
- Nome:
Test Users, adicione o filtro Test Users > Create Segment


Você criou com sucesso um segmento de usuários de teste.Agora podemos testar o envio de mensagens para este dispositivo individual e grupos de usuários de teste.
Envie um push de teste via API
- Navegue até Settings > Keys & IDs.
- No código fornecido, substitua
YOUR_APP_API_KEYeYOUR_APP_IDno código abaixo pelas suas chaves reais. Este código usa o segmentoTest Usersque criamos anteriormente.


Verifique se o dispositivo de teste recebeu uma notificação com:
- Seu ícone personalizado (se configurado)
- Imagem grande quando expandida
- Dashboard > Delivery > Sent Messages mostra o status “Confirmed” (indisponível em planos gratuitos).
Teste mensagens in-app
- Feche o aplicativo por mais de 30 segundos
- Dashboard > Messages > In-App > New In-App > selecione o template Welcome
- Público: segmento Test Users
- Gatilho: On app open
- Agendamento: Every time trigger conditions are satisfied
- Clique em Make Message Live
- Abra o aplicativo




Verifique se o dispositivo de teste recebeu uma mensagem in-app. Consulte o guia de Configuração de mensagens in-app para mais detalhes.
Você configurou com sucesso o SDK da OneSignal e aprendeu conceitos importantes como:
- Coletar Subscriptions, definir Test subscriptions e criar Segmentos.
- Enviar Push com imagens usando Segmentos e nossa API Create message.
- Enviar Mensagens in-app.
Erros comuns e correções
| Erro / Sintoma | Causa | Correção |
|---|---|---|
Cannot resolve symbol 'OneSignal' | Dependência do SDK não adicionada ou Gradle não sincronizado | Adicione a dependência ao build.gradle e sincronize o projeto |
Application class not found | Classe Application não registrada no manifest | Adicione android:name=".ApplicationClass" à tag <application> |
Google Play Services not available | Emulador/dispositivo sem Play Services | Use um dispositivo com Play Store ou emulador com Google APIs |
| Push recebido mas com ícone padrão do Android | Ícone personalizado não configurado ou nome incorreto | Crie o recurso de ícone de notificação com o nome onesignal_small_icon_default |
| Nenhuma notificação push recebida | FCM não configurado no OneSignal | Conclua o Passo 0: Configure as credenciais FCM no dashboard do OneSignal |
| Mensagens in-app não aparecem | Sessão não iniciada ou problemas de rede | Feche o aplicativo por mais de 30 segundos, reabra e verifique a conexão com a internet |
Manifest merger failed | Atributos conflitantes no manifest | Verifique se há nomes de aplicativo ou permissões duplicados |
| Otimização de bateria bloqueando notificações | Gerenciamento de energia do dispositivo | Oriente os usuários a desativar a otimização de bateria para seu aplicativo |
| Não consegue diagnosticar o problema | Informações de log insuficientes | Adicione logging verbose e verifique a saída do logcat para erros |
Gerenciamento de usuários
Anteriormente, demonstramos como criar Subscriptions mobile. Agora vamos expandir para identificar Usuários em todas as suas Subscriptions (incluindo push, e-mail e SMS) usando o SDK da OneSignal.Atribuir External ID (recomendado)
Use um External ID para identificar usuários de forma consistente entre dispositivos, endereços de e-mail e números de telefone usando o identificador de usuário do seu backend. Isso garante que suas mensagens permaneçam unificadas entre canais e sistemas de terceiros. Consulte nossa Referência do SDK Mobile para mais detalhes e exemplos de código Java.Kotlin
O OneSignal gera IDs exclusivos somente leitura para Subscriptions (Subscription ID) e Usuários (OneSignal ID).Definir o External ID via nosso SDK é altamente recomendado para identificar usuários em todas as suas subscriptions, independentemente de como foram criadas.Saiba mais sobre o método
login no guia de referência do SDK.Adicionar Tags e Custom Events
Tags e Custom Events são duas formas de adicionar dados aos seus usuários. Tags são stringskey-value e geralmente estão associadas a propriedades de usuário (como username, role ou status), enquanto Custom Events possuem formato JSON e geralmente estão associados a ações (como new_purchase, abandoned_cart e propriedades associadas). Ambos podem ser usados para potencializar Personalização de Mensagens avançada e Journeys. Consulte nossa Referência do SDK Mobile para mais detalhes e exemplos de código Java.
Kotlin
Mais detalhes sobre como usar Tags e Custom Events nos guias de Tags e Custom Events.
Adicionar subscriptions de e-mail e/ou SMS
Você pode alcançar usuários por meio de canais de e-mail e SMS, além de notificações push. Se o endereço de e-mail e/ou número de telefone já existir no aplicativo OneSignal, o SDK o adicionará ao usuário existente — não criará duplicatas. Consulte nossa Referência do SDK Mobile para mais detalhes e exemplos de código Java.Kotlin

Melhores práticas para comunicação multicanal
- Obtenha consentimento explícito antes de adicionar subscriptions de e-mail ou SMS.
- Explique os benefícios de cada canal de comunicação aos usuários.
- Forneça preferências de canal para que os usuários possam selecionar quais canais preferem.
Privacidade e consentimento do usuário
Para controlar quando o OneSignal coleta dados do usuário, use os métodos de controle de consentimento do SDK. Consulte nossa Referência do SDK Mobile para mais detalhes e exemplos de código Java.Kotlin
Consulte nossa documentação de Privacidade e segurança para mais informações sobre:
Solicitar permissões de push
Em vez de chamarrequestPermission() imediatamente ao abrir o aplicativo, adote uma abordagem mais estratégica. Use uma mensagem in-app para explicar o valor das notificações push antes de solicitar a permissão.
Para melhores práticas e detalhes de implementação, consulte nosso guia Solicitar permissões de push.
Ouvir eventos de push, usuário e in-app
Use listeners do SDK para reagir a ações do usuário e mudanças de estado. Adicione-os na sua classe Application apósOneSignal.initWithContext().
Eventos de notificação push
Kotlin
Mudanças de estado do usuário
O exemplo mostra como usar o observer de push subscription. Outros eventos de estado do usuário, como o observer de estado do usuário e o observer de permissão de notificação, estão disponíveis na Referência do SDK Mobile.Kotlin
Eventos de mensagens in-app
Métodos adicionais de mensagens in-app estão disponíveis na Referência do SDK Mobile.Kotlin
Configuração avançada e recursos
Recursos específicos do Android
- Canais de Notificação — Organize notificações em categorias (Android 8.0+)
- Service Extensions — Personalização avançada de notificações
- Suporte Huawei/HMS — Alternativa ao Google Play Services
Recursos universais
- Deep Linking — Navegue os usuários para telas específicas a partir de notificações
- Botões de Ação — Adicione botões interativos às notificações
- Verificação de Identidade — Identificação segura de usuários
- Rastreamento de Localização — Segmentação baseada em localização
- Integrações — Conecte com plataformas de análise e dados
- Mensagens Multilíngues — Notificações localizadas
Precisa de ajuda?Converse com nossa equipe de Suporte ou envie email para
support@onesignal.comPor favor inclua:- Detalhes do problema que você está enfrentando e passos para reproduzir se disponível
- Seu OneSignal App ID
- O External ID ou Subscription ID se aplicável
- A URL para a mensagem que você testou no Dashboard OneSignal se aplicável
- Quaisquer logs ou mensagens de erro relevantes