バックエンドエンジニア視点でヘッドレスCMSの魅力に迫る
こんにちは。
2023年も残り10日。クリスマスも仕事納めももうすぐですね!
2023年の締めくくりに、キャッチアップのWebエンジニア達による、ヘッドレスCMSについてのクロストークをお届けします。
日々目まぐるしく変わるWeb業界。キャッチアップでメインプロダクトとして利用している「baserCMS」もヘッドレス対応に進化しました。
ヘッドレスCMSを使うと、Webエンジニアの役割は変わるのか?業務は増えるのか?
メンバー
ヘッドレスCMSとは
ヘッドレスCMSは、ヘッド(=フロントエンド)機能がない、コンテンツ管理機能に特化したCMSです。
コンテンツ管理(バックエンド)とWebサイトへの表示(フロントエンド)が、切り離されて管理され、コンテンツの保存と管理機能に特化しています。
その為、Webサイトに限らず他のデバイスや媒体でコンテンツを表示させることが可能なCMSです。
ヘッドレスCMSは、開発に集中できる環境
ヘッドレスCMS対応になったbaserCMSをフル活用した案件で、とても開発しやすかったです。
特に、フロントのデザイン修正などの情報が届いても細かなところまで気にしなくて良いので、その分バックエンドの開発に集中できました。
なるほどー!
Webエンジニアって、フロントエンドやバックエンドって分けられているけど、従来のCMSはフロント側もバック側も全てを包括したものが一般的だったから、結局のところは、どちらの作業もしなければいけなかったよね。
でも、ヘッドレスCMSはフロントとバックが分かれているから、フロント側の作業をしなくて良くなった。というのは大きい?
そうですね、大きいと思います。バックエンドの開発作業をしていく上で、知っておかないといけない情報量がかなり減ったのかな。っていう感じがしますね。
簡単にいうと、表示する情報などが書かれた設計書さえあれば、デザイン変更があっても開発出来ちゃう。これまでは、共有された情報がどこの分野のもので、自分たちの開発に関係がある or ないの判断が必要でしたが、フロント側との構築が分担されて共有情報が減ったので、その判断がなくなったのは大きいです。
最低限の情報だけで、開発が可能となった。ってことなのかな。
フロントの開発は Next.js だったけ?
Webエンジニアから見た、ヘッドレスCMS
そうです。"お問い合わせ" などのフォームや "固定ページ"、"コンテンツ管理" とかもAPI対応されています。
やっぱり、フロントエンドとバックエンドの作業が完全に切り離せるできる状態になったことですね。
表示部分とシステム開発を分けることによってWebサイト上で不具合があった場合でも、それが見た目の問題なのか、データの問題なのかで修正担当がどちらかわかりやすくもなったと思います。あと、デザイン修正の連絡が来ないので、制作時間も短縮されたと思います。
エンジニアの作業としては、大変だったことはなかったんですが、ディレクターの方が大変だったんじゃないかと。ヘッドレスCMSを利用する場合、フロントエンドとバックエンドのサーバーが変わることがあるんですよね。なので、ヘッドレスCMSの知見がないと、考え方の切りかえが大変だったんじゃないかなって思いました。
プレビュー用のトークンが必要になりますね。
管理画面でプレビュー用のトークンを発行して、そのトークンをフロントに渡します。フロント側は受け取ったトークンでプレビュー用のデータを取得して、表示させる。っていう感じです。
つまり、表示するためのデータは管理側でつくっていて、それをWebサイトでプレビュー表示させるためには、ちゃんと認証が必要だよ。っていうことだよね。
ヘッドレスCMSって、やっぱりセキュリティ面が強くなったよね。
バックエンドエンジニアとして必要なこと
確かに。Webサイトだけじゃなくてモバイルアプリとかでも使いやすくなるのは良いですよね。
エンジニア目線でいうと、バックエンドとフロントエンドが並行して開発が進めやすいというのは良いですよね。別々に開発するよりも同時進行できると、リリースまでの時間短縮にもなるので。
そうだね。今後、バックエンドエンジニアとしてヘッドレスCMSで開発で必要なことってなんだろう。
-
API設計
-
セキュリティの知識
-
インフラの知識
-
フロントエンジニアとのコミュニケーション
こんな感じかな?
フロントエンジニアとのコミュニケーションの中でも新しい知識も必要になってきますよね。フロント側からAPIでどのようにデータを取得するかとか、フロントエンドって別サーバーにデプロイされるから、そのデプロイ方法とかを知っておいたほうが良いこともあります。
baserCMSのヘッドレス対応について
世の中のヘッドレスの流れに「baserCMS」が仲間入りした。と言う感じだよね。
ヘッドレスCMSという言葉が注目されているけど、baserCMSはヘッドレスに対応した。というだけで、これまでみたいに、フロントエンドとバックエンドを一緒に使うこともできる。そういう二刀流ができるCMSって他にない気がする。
「baserCMS」って、他のヘッドレスCMSと比べても自由にカスタマイズできるし、CakePHPを使っているから、保守性も高いし、学習もしやすいっていうところじゃないですかね。
あと個人的には、baserCMS 5系になって、CakePHP4になったのですごく書きやすくなりました。
少し長くなってしまいましたが、
『バックエンドエンジニア視点でヘッドレスCMSの魅力に迫る』
いかがでしたか?
キャッチアップのメンバーとして一緒に、成長し “できる” を共有したい方!ぜひ見学(只今オンライン)に来てくださいね!
次回もお楽しみに!!
中村からどうしても撮影してほしいと言われた、寝てる写真。
絶対に使えないのに、なんでこの写真を撮りたかったのかは不明です。苦笑