Vue.jsとFirebaseでログインとログアウトを実装する①
1.はじめに
こんにちは、アイスマイル合同会社の李です。
本連載では、Vue.jsとFirebaseを利用して、ログインとログアウトを実装したいと思います。
今回は、環境構築を行なっていきたいと思います。
※本連載では、Firebase Local Emulator Suiteを利用し、ローカル環境に限定された環境で行うため、本番環境に上げる際は別途考慮が必要であること、公式のドキュメント等ご確認いただけますようよろしくお願いいたします。
2.機能一覧
2回にかけて連載予定ですが、下記の機能を作成予定です。
・ログイン
・ログアウト
3.Firebase
Firebaseについては、下記のサービスを利用予定です。※ローカル環境では、Firebase Local Emulator Suiteを利用します。
・Firebase Authentication
・Cloud Firestore※特に利用しませんが、設定だけ行います。
4.環境構築
1)Vue.js
まずは、Vue.jsインストールを開始しましょう。
Vue (発音は /vjuː/、view と同様) は、ユーザーインターフェースの構築のための JavaScript フレームワークです。標準的な HTML、CSS、JavaScript を土台とする、コンポーネントベースの宣言的なプログラミングモデルを提供します。
https://ja.vuejs.org/guide/quick-start.html#creating-a-vue-application
npm init vue@latest
プロジェクト名など問われるかと思いますので任意の項目を選んでください。
ここでは下記のように選びました。
「Project name」: vue-firebase
「Add TypeScript?」: Yes
「Add JSX Support?」: No
「Add Vue Router for Single Page Application development? …」: Yes
「Add Pinia for state management? …」: Yes
「Add Vitest for Unit Testing? …」: Yes
「Add an End-to-End Testing Solution?」: Cypress
「Add ESLint for code quality? …」: Yes
「Add Prettier for code formatting? …」: Yes
cd vue-firebase
npm install
npm run format
npm run dev
ローカル環境が立ち上がるとアクセスしてみましょう。
http://localhost:5173/
data:image/s3,"s3://crabby-images/86430/86430fd4191888533010b6504cd610b73c752e1d" alt=""
上記のように開発環境が立ち上がれば、Vue.jsの環境は構築完了です。
2) Firebaseプロジェクト
新規のプロジェクトを作成します。
https://firebase.google.com/?hl=ja
「使ってみる」からプロジェクトを追加しましょう。
data:image/s3,"s3://crabby-images/9761f/9761f011652954d76eb20767fe7c07bc5a5e505f" alt=""
ここでは、「vue-firebase」というプロジェクト名にします。
アナリティクス設定は任意ですが、ここでは新規にアカウントを作成することにします。
data:image/s3,"s3://crabby-images/8beb6/8beb6807e60d483733e088086ed822c9b09f4901" alt=""
「プロジェクトを作成」を押しましょう。
data:image/s3,"s3://crabby-images/dc80d/dc80de2fff776ca8af92c5595aa55fe6ee2c5927" alt=""
しばらく経つと画像のような表示となりますので、続行を押してください。
3) Firebase Hosting
次に、メニューの「構築」からHostingを選択し、「始める」から各質問に答えてください。
data:image/s3,"s3://crabby-images/023f6/023f619afe1a578519cab9d941af59c77a482256" alt=""
「Firebase JavaScript SDK をウェブアプリに追加する手順も表示する」にチェックを入れて、次へ進めてください。
data:image/s3,"s3://crabby-images/e9a57/e9a5750211b159704b94354b913279562838665c" alt=""
アプリを登録する箇所で、アプリ名を「vue-firebase」とします。
登録が完了し、コンソールへ進めば完了です。
4) Firebase Authentication
次に、構築から「Authentication」を選択し、進めてください。
data:image/s3,"s3://crabby-images/b0d1d/b0d1d06b032b8ee25da096fe3709420a230a1e61" alt=""
「メール/パスワード」を選択してください。
data:image/s3,"s3://crabby-images/6c4f9/6c4f9b1323948075bf6178361c2d437859844097" alt=""
「メール/パスワード」を有効にし、保存してください。
data:image/s3,"s3://crabby-images/a34ac/a34ac9381cc08afd1518933a57b512a509b7d358" alt=""
5)Cloud Firestore
構築から「Firestore Database」を選択し、データベースの作成を進めてください。
data:image/s3,"s3://crabby-images/c5d87/c5d876a972dbb19aa04a22d766172c063fab676b" alt=""
本番環境モードで特に問題ないです。次へ進めてください。
data:image/s3,"s3://crabby-images/857b8/857b87d2de2b4c783d63e2c912fac1c696cf9a42" alt=""
ロケーション設定はここでしかできないので適切なロケーションを設定してください。
ここでは、「asia-northeast1(Tokyo)」を選択し、有効にします。
data:image/s3,"s3://crabby-images/77630/77630bee16231b889d7a374ab1cb294937292de8" alt=""
6) Firebase Local Emulator Suite
次に、Firebase Local Emulator Suiteをインストールしたいと思います。
Firebase Local Emulator Suite は、アプリのビルドとテストをローカルで行うことのできる、デベロッパー向けの高度なツールセットです。Cloud Firestore、Authentication、Firebase Hosting、Cloud Functionsを含めていろんなFirebaseのサービスをエミュレートしてくれます。
https://firebase.google.com/docs/emulator-suite?hl=ja
(1)Firebase CLI をインストールする
インストールがまだの場合、各環境に合わせて、CLIをインストールしてください。
https://firebase.google.com/docs/cli?hl=ja#install_the_firebase_cli
プロジェクト一覧が表示できるようになったら完了です。
firebase projects:list
(2)Firebase Local Emulator Suite
先ほど作成したプロジェクト直下にいることを確認してください。
もし、そうでない場合は、移動してください。
cd vue-firebase
次に、先ほどインストールしたFirebaseのCLIを使ってエミュレータをセットアップします。
firebase init
エミュレータは下記を選択します。
◉ Authentication Emulator
◉ Firestore Emulator
◉ Hosting Emulator
後の質問は、デフォルトで問題ないのでEnterを押しましょう。
? Which port do you want to use for the auth emulator? 9099
? Which port do you want to use for the firestore emulator? 8080
? Which port do you want to use for the hosting emulator? 5000
? Would you like to enable the Emulator UI? Yes
? Which port do you want to use for the Emulator UI (leave empty to use any available port)?
? Would you like to download the emulators now? Yes
i Writing configuration info to firebase.json...
i Writing project information to .firebaserc...
✔ Firebase initialization complete!
ここまで出来たら、 エミュレーターを立ち上げてみましょう。
firebase emulators:start
立ち上がったら下記にアクセスしましょう。
http://127.0.0.1:4000/
data:image/s3,"s3://crabby-images/6b3be/6b3bef7a555aef69a3147586245239b3e64c1c22" alt=""
構築完了です。
5.おわりに
次回、ログインを実装したいと思います。