Monaca Docs
  • Monaca
  • Create Your First App
  • Release Notes and Updates
    • Privacy Manifest Requirement for iOS Apps
    • Plugin uses-permission Tag Deduplication Feature
    • iOS Monaca Debugger Discontinuation & Alternative Features
    • Error submitting to iOS App Store (ITMS-90165)
    • Build error in cordova-custom-config
    • Cordova 11 changes
    • Cordova 10 changes
    • Cordova 9 changes
    • New Monaca CLI and Localkit
    • Migration from Cordova to Capacitor
  • Product Guides
    • Monaca Development Overview
    • Monaca Cloud IDE
      • Overview
      • Features in the Monaca Cloud IDE
      • Integrated Terminal
      • Editor Shortcuts
      • Project Dependencies
        • File and Folder Structure
        • JS/CSS Components
        • Cordova Plugins
        • Custom Cordova Plugins
      • Version Control
        • Introduction
        • GitHub Integration
        • Git SSH Integration
      • Monaca CI
        • Overview
        • Deploy Services
        • Deploy to Appetize.io
        • Deploy to DeployGate
        • Deploy to Firebase
      • Build
        • Building for iOS
          • Building an iOS App
          • Build Settings between Monaca and Xcode
        • Building for Android
        • Building for Electron
          • Building on Windows
        • Building for PWA
        • Building for Windows
        • Build Environment Settings
        • Common Build and Application Upload Errors
        • Build History
      • Distribution
        • App Store Distribution
          • App Store Connect Guide
          • iOS App Upload Feature
        • Google Play Distribution
        • Amazon Appstore Distribution
        • Non-market App Distribution
      • Download App Package
      • Tutorial
    • Monaca Localkit
      • Overview
      • Pairing and Debugging
      • Remote Building and Publishing
      • Troubleshooting Guide
      • Tutorial
    • Monaca CLI
      • Overview
      • Monaca CLI Commands
      • Pairing and Debugging
      • Project Dependencies
        • File and Folder Structure
        • JS/JSS Components
        • Cordova Plugins
        • Custom Cordova Plugins
      • Remote Building and Publishing
      • Troubleshooting Guide
      • Tutorial
    • Monaca Debugger
      • Functionalities
      • Installation
        • Monaca Debugger for Android
        • Monaca Debugger for iOS
        • Monaca Debugger for Android Emulator
      • Usage
      • Custom Build Debugger for iOS
      • iOS App Simulator Build
      • Troubleshooting Guide
      • Tutorials
    • Team Dashboard
    • Quick Viewer
    • Migrating from Other Platforms
      • Key Points
      • Cloud IDE preview function settings
      • Migrating from Angular
      • Migrating from Ionic
      • Migrating from React
      • Migrating from Vue
      • Migrating from PhoneGap
        • Key Differences
        • Guide for PhoneGap Build Users
        • Guide for PhoneGap CLI Users
        • Guide for PhoneGap Desktop App Users
      • Migrating from Telerik
  • Build App
    • Build for iOS
      • Creating a Private Key and CSR
      • Creating a Certificate
      • Updating Provisioning Profiles
  • Tutorials
    • Monaca Cloud IDE Tutorial
      • Part 1: Starting a Project
      • Part 2: Running Monaca Debugger with Monaca Cloud IDE
      • Part 3: Building a Monaca App
      • Part 4: Publishing a Monaca App
    • Monaca Localkit Tutorial
      • Part 1: Starting a Project
      • Part 2: Running Monaca Debugger with Monaca Localkit
      • Part 3: Building a Monaca App
      • Part 4: Publishing a Monaca App
    • Monaca CLI Tutorial
      • Part 1: Starting a Project
      • Part 2: Running Monaca Debugger with Monaca CLI
      • Part 3: Building a Monaca App
      • Part 4: Publishing a Monaca App
    • Electron Tutorial
      • How to Use a NPM Package
      • How to Use a Web API
    • Barcode Scanner Plugin
    • Cordova SQLite Storage Plugin
    • Cordova Google Analytics Plugin
    • Cordova Firebase Plugin
    • Cordova In-app Purchase Plugin
    • Cordova AppVersion Plugin
    • Cordova Ionic Keyboard Plugin
    • Cordova Social Sharing Plugin
    • NIFCLOUD mobile backend
    • Phonegap Push Plugin
  • API Reference
    • Monaca API
      • Monaca Cloud & Remote Build API Guide
      • Utilities
    • Core Cordova Plugins
      • Cordova 11.0
        • Battery Status Plugin
        • Camera Plugin
        • Device Plugin
        • Device Motion Plugin
        • Device Orientation Plugin
        • Dialogs Plugin
        • File Plugin
        • Geolocation Plugin
        • InAppBrowser Plugin
        • Media Plugin
        • Media Capture Plugin
        • Network Information Plugin
        • Splashscreen Plugin
        • Vibration Plugin
        • StatusBar Plugin
      • Cordova 10.0
        • Battery Status Plugin
        • Camera Plugin
        • Device Plugin
        • Device Motion Plugin
        • Device Orientation Plugin
        • Dialogs Plugin
        • File Plugin
        • Geolocation Plugin
        • InAppBrowser Plugin
        • Media Plugin
        • Media Capture Plugin
        • Network Information Plugin
        • Splashscreen Plugin
        • Vibration Plugin
        • StatusBar Plugin
        • Whitelist Plugin (Android Only)
      • Cordova 9.0
        • Battery Status Plugin
        • Camera Plugin
        • Contacts Plugin
        • Device Plugin
        • Device Motion Plugin
        • Device Orientation Plugin
        • Dialogs Plugin
        • File Plugin
        • File Transfer Plugin
        • Geolocation Plugin
        • Globalization Plugin
        • InAppBrowser Plugin
        • Media Plugin
        • Media Capture Plugin
        • Network Information Plugin
        • Splashscreen Plugin
        • Vibration Plugin
        • StatusBar Plugin
        • Whitelist Plugin (Android Only)
    • Third-party Cordova Plugins
      • Advanced HTTP Plugin
      • PhoneGap BarcodeScanner Plugin
      • Cordova Custom Config Plugin
      • DatePicker Plugin
      • Share Plugin (Android)
      • WebIntent Plugin (Android)
    • Monaca Power Plugins
      • Monaca HTML5 Resource Encryption
      • Monaca In-App Updater
      • Monaca Secure Storage
      • Barcode Scanner Plugin
      • Android build memory size setting
    • Service Integration
      • Repro
      • AppsFlyer
    • Configuration Files
      • Android
        • Android Configuration
        • config.xml
        • AndroidManifest.xml
      • iOS
        • iOS Configuration
        • config.xml
        • MonacaApp-Info.plist
  • Samples & Tips
    • Sample Apps
      • AdMob
      • Twitter Single Sign-on App
      • Facebook Single Sign-on App
      • Flickr
      • TODO App
      • BirthYear App
      • Break the Bricks
      • Train Catalog App
      • Omikuji Fortune Telling App
      • Clock App
      • Memo Application
      • RSS Reader App
      • Hello World App
    • Tips & Tricks
      • Playing Sound and Music
      • Control the Splash Screen
      • Using Database
  • Features
    • Push Notification
    • SNS Authentication
    • Database
  • FAQ
    • General
    • IDE
    • Build
    • Release
    • Subscription
      • How to Use Activation Code
    • Application
    • Usage
    • Debugger
  • Supported Environments
  • Trouble Shooting
    • Preview Log repeats to reload (Vue packages version mismatch error)
  • Monaca Product Website
  • 日本語
Powered by GitBook
On this page
  • Overall
  • Configuration in Firebase
  • Create a new project
  • Setting up Cloud Messaging (creating a configuration file)
  • Generate private key
  • Configuring in NIFCLOUD mobile backend
  • Configuring in Monaca
  • Adding a plugin
  • Android App Settings
  • Upload google-services.json
  • Writing Code
  • Send push notifications

Was this helpful?

  1. Tutorials

NIFCLOUD mobile backend

Overall

To set up push notifications for Android, you will need to configure settings for the following services.

  1. Firebase settings

  2. NIFCLOUD mobile backend settings

  3. Configuration on Monaca

Configuration in Firebase

In Firebase, create a new project and get the following two files

  • Configuration file:

    • google-services.json

  • Private key file:

    • xxxx-firebase-adminsdk-xxxxxx-xxxxxxxx.json

    (Note that the private key has a different file name for each project.)

After obtaining the two files, the configuration file is set to the Monaca project.

The private key file is set to the NIFCLOUD mobile backend.

Create a new project

Setting up Cloud Messaging (creating a configuration file)

In Android package name, enter the package name you decided. You can omit the application nickname and signing certificate.

When you register your app, you can download a file 'google-services.json' . We will use this file later.

Generate private key

Return to the Firebase project home page, click the gear icon in the upper right corner, and click Project Settings.

When the project settings are displayed, click on the Service Account tab. Then click the Generate New Private Key button at the bottom.

Configuring in NIFCLOUD mobile backend

Click App Settings in the upper right corner and select Allow push notifications in the Push Notifications menu.

In addition, upload the private key file (file name like xxxx-firebase-adminsdk-xxxxx-xxxxxxxx.json) that you just downloaded from Firebase as a push notification configuration file (json) in the Android push notifications section below that.

You can also get the application key and client key from NIFCLOUD mobile backend. We'll use them later.

Configuring in Monaca

Adding a plugin

Open the app you want to implement push notifications for. Or create a new one.

After opening the Cloud IDE, select Manage Cordova Plugins in the Settings menu.

Select 'NIFCloudMB' in the plugin list and press the Enable button.

Android App Settings

Select Android App Settings in the Settings menu.

Then, enter the Android package name.

Upload google-services.json

Upload google-services.json to the root (/) of the Monaca project.

With the file in the root (e.g. package.json) selected, select Upload from the File menu. Then drop google-services.json in the dialog that comes up and upload it.

Writing Code

Create an arbitrary JavaScript file and load it in www/index.html. In this case, www/app.js is created and loaded.

<script src="app.js"></script>

app.js

Here is the content of app.js.

  • window.NCMB.monaca.setDeviceToken

    • Obtains the device token and stores it in the NIFCLOUD mobile backend.

  • window.NCMB.monaca.setHandler

    • This is called when a push notification is received.

YOUR_APPLICATION_KEY and YOUR_CLIENT_KEY should be replaced with the keys you got from NIFCLOUD mobile backend respectively.

const e = window.cordova ? 'deviceready' : 'DOMContentLoaded';

document.addEventListener(e, async () => {
    try {
        const res = await new Promise((res, rej) => {
            window.NCMB.monaca.setDeviceToken(
                "YOUR_APPLICATION_KEY",
                "YOUR_CLIENT_KEY",
                res,
                rej
            );
        });
        console.log(res);
    } catch (e) {
        console.log(e);
    }

    // For opening notification
    window.NCMB.monaca.setReceiptStatus(true);

    window.NCMB.monaca.setHandler(jsonData => {
        alert(JSON.stringify(jsonData));
    });
});

Send push notifications

After installing the app, launch it and make sure the device token is registered in the Installation class of the NIFCLOUD mobile backend.

Then create a push notification in NIFCLOUD mobile backend.

Wait a bit and you will see the push notification on your Android screen.

PreviousCordova Social Sharing PluginNextPhonegap Push Plugin

Last updated 2 years ago

Was this helpful?

Go to and create a project.

Setting up Cloud Messaging (creating a configuration file)

Access . Create a new app.

Firebase
NIFCLOUD mobile backend