定制 open-php/firebase-fcm-notification 二次开发

按需修改功能、优化性能、对接业务系统,提供一站式技术支持

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

open-php/firebase-fcm-notification

最新稳定版本:V1.0.1

Composer 安装命令:

composer require open-php/firebase-fcm-notification

包简介

A robust PHP library for sending Firebase Cloud Messaging (FCM) notifications using the HTTP v1 API. Features include simple access token management, topic messaging, and support for rich notifications with images.

README 文档

README

Latest Version on Packagist Total Downloads License

A robust and easy-to-use PHP library for sending Firebase Cloud Messaging (FCM) notifications using the Google HTTP v1 API.

This library encapsulates the complexity of generating JWT tokens for Google Auth and making requests to the FCM v1 API.

Features

  • HTTP v1 API Support: Uses the latest Firebase v1 API.
  • Service Account Authentication: handled automatically via service_account.json.
  • Flexible Targeting: Support for sending to specific device tokens or topics.
  • Rich Notifications: Support for title, body, and image.
  • PSR-4 Autoloading: Easy integration with Composer.

Folder Structure

firebase-fcm-notification/
├── src/
│   └── FcmNotification.php  <-- Main Library Class
├── composer.json            <-- Dependency Management
├── index.php                <-- Example Usage (HTTP)
└── service_account.json     <-- Your Firebase Credentials (NOT INCLUDED)

Installation

  1. Install dependencies via Composer:

    composer require open-php/firebase-fcm-notification

    (Or running composer install if you cloned this repo)

  2. Setup Credentials:

    • Go to the Firebase Console.
    • Navigate to Project Settings > Service accounts.
    • Generate a new private key and save the JSON file as service_account.json in your project root (or anywhere secure).

Usage

Basic Usage

require 'vendor/autoload.php';

use OpenPhp\FirebaseFcm\FcmNotification;

try {
    // 1. Initialize with path to service account JSON
    $fcm = new FcmNotification('./service_account.json');

    // 2. Send a notification
    $title = "Hello World";
    $body = "This is a test notification";
    $token = "DEVICE_FCM_TOKEN"; 

    $result = $fcm->send($title, $body, $token);

    print_r($result);

} catch (Exception $e) {
    echo "Error: " . $e->getMessage();
}

Advanced Usage (Topics & Images)

// Send to a topic
$isTopic = true;
$target = "news"; // Topic name
$imageUrl = "https://example.com/image.png";

$result = $fcm->send($title, $body, $target, $isTopic, $imageUrl);

Class & Methods

OpenPhp\FirebaseFcm\FcmNotification

__construct($serviceAccount)

Initializes the FCM client.

  • $serviceAccount (string|array): Path to the service_account.json file OR an associative array containing the JSON data.

send($title, $body, $target, $isTopic = false, $imageUrl = null)

Sends a notification.

  • $title (string): Notification title.
  • $body (string): Notification body text.
  • $target (string): Device registration token OR topic name.
  • $isTopic (bool): Set to true if $target is a topic name. Default false.
  • $imageUrl (string|null): Optional URL to an image to display in the notification.
  • Returns: array (FCM API response) or ['error' => string] on failure.

Support

License

This project is licensed under the MIT License. See LICENSE file for details.

Author

统计信息

  • 总下载量: 4
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 0
  • 点击次数: 4
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 0
  • Watchers: 0
  • Forks: 0
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2026-01-19

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固