WordPressにプッシュ通知をつけるプラグイン(と通知用API)を作ったお話

  • このエントリーをはてなブックマークに追加

最近は企業サイトやブランドサイトでもWordPress(以下WP)でのサイト構築が増えてきました。

弊社でもWPでのサイト構築やリニューアルなどが増えてきており、今後も需要が増えてくると思います。

また、今使っているWPのサイトをアプリ化したい(WebViewなどで)という事もあるかと思うので、その場合、比較的簡単にプッシュ通知を実装できるプラグイン(と通知を行うAPI)を作ってみました。

どんな構成

WPがPHPで動くので、開発言語はPHPとなります。

今回はプッシュ通知の登録管理をWP上で行いたいのでプラグインとして使います。

また、実際にプッシュ通知を行うのはプラグイン上ではなく、別途作成するAPIから通知するため(理由は後述)、構成としてはWPのプラグイン+独自APIという構成となります。

ちなみになぜプッシュ通知処理をWordPressで行わなかったかというと、

  • WordPress上ではデフォルトでREST API形式が使えない
  • cron設定が行えない(wp-cronはサイトアクセスしたときに動くため)
という2点から、独自のAPIを実装しました。

プラグインはどんな機能?

プラグイン上でプッシュ通知の管理を行うのですが、こちらで「いつ」「どんな内容を」送るのか設定できます。



即時通知にチェックを入れると即時で通知、予定日時(15分刻み)を設定するとその時刻になると一斉にプッシュ通知を送ります。

今回のバージョンではiOS、Androidのセグメントを行っていませんが、データ上は行えるようになっています。

APIはどんな機能?

プラグインの役割は大きく分けて2つあります。
  • アプリからプッシュ通知登録/解除
  • プラグインからのプッシュ通知配信 / cronによるスケジュール配信
すべてREST APIで処理を行います。

他に必要な情報は?

PUSH通知を実装するに当たりFirebase Cloud Messaging(以下FCM)を使っていますので、Firebaseのアカウントが必要です。

その他、iOSアプリで実装するため、APNsの証明書と暗号化キーが必要となります。

このあたりは実際にプッシュ通知を実装する際に必要な情報ですので、既にプッシュ通知を使っている場合はお手元にあるかと思います。

あとは通知を受信するアプリとなります。

アプリに必要な機能としては「通知の登録/解除(REST APIで通信)」と通知処理となります。

詳しいことは・・・

今回は割と技術的な部分から説明しましたが「ちょっと興味がある」という方は弊社の方で資料を作成しておりますので、こちらをご覧ください。(無料です)

資料ダウンロード

執筆者:松本[ エンジニア ]

関連記事

マークアップ

【CSSのみ】スムーススクロール+アンカーリンク時の固定ヘッダーのずれを調整

今までの流れで、何となくスムーススクロールやアンカーリンク時の固定ヘッダーのずれをjsなどで処理していませんか? 実はCSSのみで対応できるようになっています。 主要なブラウザには対応していて、なおかつ簡単にできるので、ぜひ使っていきましょう。 目次1 CSSだけでスムーススクロールをする1.1 実際のイメージ2 CSSだけでアンカーリンク時の固定ヘッダーのずれを調整する2.1 実際のイメージ CSSだけでスムーススクロールをする まずはcssだけでスムーススクロールをする方 […]

Webデザイン

【Photoshop】生成塗りつぶしを使ってみよう【AI】

Photoshop 2024(ver.25)から本格的にAIによる生成機能が追加されました。 今回はどんなことができるか、基本的なものをご紹介していきます。 目次1 対象のものを削除したい2 カンバスを広げて、画像を拡張する3 要素をほかのものに置き換える4 元々存在しない要素を付け足す 対象のものを削除したい ではまず、対象のものを削除する方法です。 Photoshop 2024(ver.25)で生成塗りつぶしに使いたい画像を開きましょう。 画像を開いたら、削除をしたいもの […]

Webデザイン

【AI画像生成】Adobe Fireflyを使ってみよう!【商用利用可】

昨今ますます勢いを増すAI画像生成。 今回はAdobe社の提供するFireflyという画像生成AIを使ってみましょう。 このような高画質の画像を生成することができます。 目次1 Adobe Fireflyの特長1.1 著作権問題がクリア1.2 商用利用可1.3 無料ユーザーでも使用可能1.4 新たにツールなどをダウンロードする必要なし2 Fireflyの使い方2.1 1.Fireflyにアクセス2.2 2.「テキストから画像生成」を押す2.3 3.生成したい内容のテキストを入 […]

株式会社8bit (エイトビット)

東京都目黒区でWebサイト制作、Webシステム開発などを行っております。
コーポレートサイトやWebサービスの企画・提案を得意としており、自社での経験を元にアイデアをカタチにするお手伝いをさせていただいております。

Web制作に関するご相談はお気軽にどうぞ

弊社に制作をご依頼いただく際の費用感をご確認いただける、
見積りシミュレーションをご用意いたしました。