はじめに(この記事の対象読者)
今、会社でstrapiを使った開発が複数走っています。
僕はプロダクトオーナー的な立場で関わっているのですが、その立場から見てもstrapiって非常に魅力的なので、Qiita Advent Calendarに便乗して紹介記事を書かせていただきました。
なお、この記事の読者は以下のような人を想定しています。
- WordPressじゃ高機能なWebシステムの基盤として使うには少し厳しいと感じ始めている人
- HeadlessCMS(ヘッドレスCMS)は聞いたことがあるけど使い所がわからないよって人
- HeadlessCMSいくつかあるけど、どうやって選ぼうかなと考えてる人
逆に以下のような人は別記事へ飛ぶのがオススメです。
- strapiのカスタマイズ方法など技術的な内容を調べたい人
- 既にHeadlessCMSを導入していて割と詳しい人
HeadlessCMS / strapiとは
HeadlessCMSやstrapiについて紹介している記事は既に山ほどあるので、本稿では独断と偏見に満ちた内容を記したいと思います。
なので、わかりやすくHeadlessCMSを説明しているこの辺りの記事を合わせて読むことを強くお勧めします。
HeadlessCMS?
さて、HeadlessCMS(ヘッドレスシーエムエス)とはなんでしょうか。
これは一言で言ってしまえば管理画面とAPIだけを機能として提供するCMSです。
バックエンドとフロントエンドが完全に分離しているのでWordPressのようなバックもフロントも全て一緒に管理するCMSよりも、扱う範囲が狭いのでCMS自体のセキュリティが結果として高まる(WordPressなどのフルパッケージのCMSの場合、フロントエンドのセキュリティホールによりバックエンドの情報が引っこ抜かれる、など1つのセキュリティーホールの影響範囲が広くなる傾向がある)というメリットもあります。
でも、やっぱり一番はユーザーにとっては「バグなく動いて当たり前」の管理画面を提供してくれた上でフロントエンドは自由に作れるというその基本的なところが今のモダンな開発スタイルにマッチしているということに尽きると思います。
###strapi?
strapi(ストラーピ)はそのHeadlessCMSの一つです。
HeadlessCMSは大きく分けて2つの種類があります。
クラウドサービスとして提供されているものとセルフホスティング型のものです。
前者はアカウントを作って料金を支払って使うサービス(多くのものは無料枠が存在します)で、後者のセルフホスティング型はその名の通り自分で動作環境を構築し、そこにホスティングするものを指します。
strapiはセルフホスティング型のHeadlessCMSでオープンソースで提供されています。
この辺りは一概にどちらが良いかは判断しにくいのですが、クラウドサービスとして提供されているものは、多くの場合、スタートアップ企業が提供しています。
この会社が倒産してしまったり、サービスを停止するとなった場合のダメージをどの程度まで受け入れられるか、というのが一つの判断基準にはなるのではないでしょうか。
ただ、やっぱりサービスとして提供してくれているものは使うの楽なんですよねえ笑
Ghost, directusとstrapiの比較
strapiは今までも述べた通り、セルフホスティング型のHeadlessCMSです。
その形で提供しているものはGhostやdirectusなどがあります。
HeadlessCMSを使いたくて、自分でホスティングしたい、となったら大体上の2つにstrapiを入れた3つが比較対象になるんじゃないかと思います。
ちなみに、クラウドサービス型だったら日本製のmicroCMSがなんだかんだドキュメント類も日本語で最初から提供されているんで日本人にはオススメです。
クラウドサービス型を選ぶってことは管理や開発を楽に行いたいという動機がかなり強いと思うので、だったらドキュメントやサポートが母国語ってのは大きな採用理由になります。
さて、話を戻すと上記の3つのセルフホスティング型のCMSに「このCMSだけでしか、これは出来ない」というのは無いように見えます。
※当然、 なんちゃらの実装はstrapiの方がやりやすいなどはあります。
それなら、ということで判断基準として管理画面のUIを比較してみるのも良いと思います。
以下では簡単にGhost, directus, strapiの管理画面からみた使い所の比較を行っていました。
Ghost
まずは、Ghostの管理画面ですが、こんな感じです(出典:Ghost公式)
元々がブログ特化型のCMSであることもあって、ブログの執筆・管理が非常にやりやすいUIになっています。
また、Stripe(strapiでは無いですよ!)を使用したサブスクリプション課金の実装・メンバー管理などもやりやすく、**メディア運営するならGhost**という感じです。
directus
directusはこちら。ウサギが可愛いです。(出典:directus公式)
directusの管理画面はデータ構造がわかりやすく、ファイル管理も洗練されている印象があります。
大量のデータを扱うECサイトやデータ管理の基盤として使う、などの用途に向いていると感じました。
ちなみに、directusはもうほとんど更新はしていないんですが Youtubeチャンネルもあります。見てみると利用イメージがさらにわくかもです。
strapi
さて、最後にこの記事の主役のstrapi管理画面です。
これは弊社で開発中のサービスの管理画面のキャプチャです。
印象としてはGhostとdirectusの中間、と言った感じでしょうか。非常にシンプルなUIです。
特徴としてはコレクションタイプとプラグインの概念。
strapiでは管理画面からデータモデルを定義してコレクションタイプとして追加出来ます。
上記の画面はいわゆるノウハウ共有サイトの管理画面なのですが、投稿内容の種類に応じたデータモデルの設計が画面上からできる形です。
もう一つのプラグイン。
これはもうそのままなのですが、追加機能をプラグインとして実装&追加が可能です。
プラグインの存在により、バックエンド側にもある程度の自由度があるのは非常に助かります。
では、strapiはどんなケースで有効なのかというと、ユーザー投稿型のサイトで集計機能などの自分たちで作らないといけない追加機能を複数有するもの、なのかなと感じています。
(まあ、なので今開発しているサービスのCMSとしてstrapiを採用したんですが)
あと、UI関係ないんですが、strapiって導入簡単なんですよ。
それも採用理由の一つでした。
#終わりに
どんな技術も使いどころを間違えれば微妙だし、正しく使えば非常に有用です。
strapiも同じであらゆるサービス開発で使うべし!ということではないのですが、勘所を抑えれば基本的にはAPIを使ってフロント側でどーこーするものなので学習コストもそんなに高くないし、利用検討している人は一回触ってみるのも良いと思います。
strapi、日本での盛り上がりはまだまだなので一緒に盛り上げていきましょう!