Firebase Hosting の機能を使えば、サーバサイドが苦手な方(筆者含む)でも簡単にWebページを表示することができます。
iOS や Android アプリに表示する簡単な静的ページ(利用規約など)を表示する場合などに、わざわざ自分でレンタルサーバに環境構築する必要もなく、お手軽に実現することができます。
Firebase Hosting を利用してWebページを表示する手順
予め、Firebase プロジェクトが作成済みである前提で話を進めます。
Firebase プロジェクトの作成については下記の記事の(1)・(2)をご参考ください。
(1) Firebase CLI ツールのインストール
コンソール画面から[Hosting]メニューを開き、「始める」をクリックします。
data:image/s3,"s3://crabby-images/09b2f/09b2f3a6ca05ba1a76686abed4155721744b364e" alt=""
最初に npm install で Firebase CLI ツール群をインストールします(インストール手順は後述)。
インストール後に「次へ」で次の手順へ進みます。
data:image/s3,"s3://crabby-images/cb6c0/cb6c005d2d9962ba78e15a0d3334e4a22417f58e" alt=""
そもそも npm がインストールされていないと実行できませんので以下の手順通り進め、npm を使えるようにしましょう。
既に npm がインストールされている、または、その事前準備である Home brew 等がインストール済みであれば (1)〜(3) についてはスキップしてください。
(1) Home brew のインストール(インストールされていない場合のみ)
% /bin/bash -c "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/master/install.sh)"
(2) nodebrew のインストール(インストールされていない場合のみ)
% brew install nodebrew
nodebrew コマンドへの環境パスを通します。
% echo 'export PATH=$HOME/.nodebrew/current/bin:$PATH' >> ~/.bash_profile
% source ~/.bash_profile
nodebrew のバージョンを確認して見ましょう。
% nodebrew -v
nodebrew 1.0.1
(3) Node.js のインストール(インストールされていない場合のみ)
Node.js をインストールすることで、同時に npm もインストールされます。
インストール先のディレクトリを作成したあとインストールします。
% mkdir -p ~/.nodebrew/src
% nodebrew install-binary latest
Node.js のバージョンを確認します。
current: none となっているのは使用するバージョンが未設定なためです。
% nodebrew ls
v15.5.1
current: none
複数のバージョンがインストールされている場合もあるため、使用バージョンを設定する必要があります。
% nodebrew use v15.5.1
再度、バージョン確認をしてみると current: (バージョン名)となっているはずです。
% nodebrew ls
v15.5.1
current: v15.5.1
同時に、npm コマンドもインストールされているはずなのでバージョン確認します。
% npm -v
7.3.0
(4) Firebase CLI ツールのインストール
ようやく本題です。npm install コマンドでインストールしましょう。
% npm install -g firebase-tools
Firebase CLI がインストールされたか確認します。
% firebase --version
9.1.2
インストール後は「次へ」「コンソールに進む」と進むと、ダッシュボード画面が表示されます。
data:image/s3,"s3://crabby-images/df219/df2194a1a81e95387f0305950df05cf8ede5fb8e" alt=""
data:image/s3,"s3://crabby-images/9c418/9c418aee3fa78d8457db57d811f3660b4ab21b6f" alt=""
data:image/s3,"s3://crabby-images/4700d/4700d1ed933c6d4c02dc2299c83ea7f550c34a21" alt=""
上記の赤枠のURLをクリックすると以下のような画面が表示されるはずです。
data:image/s3,"s3://crabby-images/2dbe8/2dbe87fa87c5d96175795b60194caf6bbd4523ac" alt=""
この時点ではサイトのデプロイを待っているという状況になります。
(2) サイト(静的ページ)のデプロイ手順
firebase login
先ず、ローカルの作業環境に任意のディレクトリを用意します。この例ではデスクトップ直下としています。
% cd Desktop
% mkdir 任意のディレクトリ名
% cd 任意のディレクトリ名
firebase login で Google アカウントにログインします。
% firebase login
下記のようにFirebaseCLIの許可を尋ねられるので [Y+Enter]を押下します。
? Allow Firebase to collect CLI usage and error reporting information? (Y/n)
すると、ブラウザが開いてGoogleログイン画面が表示されるので任意のGoogleアカウントでログインします。
data:image/s3,"s3://crabby-images/6e071/6e071889023143bd6a5c5ee23f17f8e9a607d496" alt=""
「許可」をクリックして Firebase CLI のアクセスを許可します。
data:image/s3,"s3://crabby-images/593f4/593f441fa0ffb4df05b5fdc7821edd998f18cdf7" alt=""
以下のようなブラウザの画面と、ターミナルの表示がされればOKです。
data:image/s3,"s3://crabby-images/a5070/a507077a44cccb8b505009519c1b5ca095e261c8" alt=""
✔ Success! Logged in as **********@gmail.com
firebase init
続いて Firebase Hosting への初期化を行います。
% firebase init
以下のキャプチャのような表示がされるので、方向キーで Hosting にカーソルを合わせスペースキーを押下しエンターキーで次へ進みます。
data:image/s3,"s3://crabby-images/ac23b/ac23b39ebdd76cb675cf88e9ad181095d03b0cc5" alt=""
続いて、対象のプロジェクトを選択します。
作成済みの Firebase プロジェクトを指定するので [Use an existing project] を選択します。
data:image/s3,"s3://crabby-images/4cb67/4cb67570a1f7d304873883500fd4abd1ad760765" alt=""
対象のプロジェクトを選択します。
data:image/s3,"s3://crabby-images/366ff/366ffde6a3ff1b3d14e412b64a5867a1132c1b16" alt=""
公開するコンテンツのディレクトリを聞かれるので、今回はデフォルト(public)のままとしたいのでエンターを押します。
? What do you want to use as your public directory? (public)
SPA(Single Page Application)に適した設定にするか聞かれますが、ここは[N+Enter]で進めます。
? Configure as a single-page app (rewrite all urls to /index.html)? (y/N)
GitHub で自動ビルド&デプロイ環境をセットアップするか聞かれますが、本題から逸れそうなので今回は遠慮して [N+Enter] で進みます。
? Set up automatic builds and deploys with GitHub? (y/N)
以下のように表示されれば初期化完了です。
✔ Wrote public/404.html
✔ Wrote public/index.html
i Writing configuration info to firebase.json...
i Writing project information to .firebaserc...
i Writing gitignore file to .gitignore...
✔ Firebase initialization complete!
ディレクトリに public ディレクトリと firebase.json が作られているか確認しておきましょう。
% ls
firebase.json public
ローカル環境での確認
firebase serve コマンドでローカル環境でHostingを確認できます。
% firebase serve
=== Serving from '/Users/satokichi/Documents/WebApp/MySDGs-dev'...
i hosting: Serving hosting files from: public
✔ hosting: Local server: http://localhost:5000
http://localhost:5000 にアクセスすると以下の画面が表示されるはずです。
data:image/s3,"s3://crabby-images/05826/0582679f9ac016d1f2b8daca82f4099a7987222b" alt=""
ちなみに、[control+C]でシャットダウンできます。
Webにデプロイする
続いて、実際のインターネットにデプロイしてみます。
public ディレクトリに移動し、firebase deploy を実行します。
% cd public
% firebase deploy
data:image/s3,"s3://crabby-images/967e1/967e11b1caf16efd475c5e0742b20bb97f8a45f7" alt=""
無事デプロイが成功していれば、Hosting した URL にアクセスすると先程と同じ画面が表示されるはずです。
data:image/s3,"s3://crabby-images/05826/0582679f9ac016d1f2b8daca82f4099a7987222b" alt=""
また、コンソール画面を確認するとデプロイ履歴が更新されているのが確認できます。
data:image/s3,"s3://crabby-images/b6db4/b6db494b3dc4c33cc21a2d90d01cf49bdb7a9cc2" alt=""
テストページを表示する
index.html ではなく、独自に用意したHTMLページを表示してみます。
public 下に以下のような内容の sample.html というファイルを用意しました。
% touch sample.html
% ls -l
404.html
index.html
sample.html
% vi sample.html
内容は適当です。
<!DOCTYPE html>
<html lang="ja">
<head>
<meta charset="UTF-8">
<title>Firebase Hosting テストページ</title>
</head>
<body>
<h1>Firebase Hosting のテストページですよ</h1>
</body>
</html>
再度デプロイしなおします。
% firebase deploy
https://(プロジェクト名).web.app/sample.html でアクセスしてページが表示されれば成功です。
data:image/s3,"s3://crabby-images/eae9a/eae9ae74ec46c640bafdbe7c78583db46737dae0" alt=""
おまけ:iOSアプリから表示してみる
試しにSwiftUIアプリからLinkを利用して外部ブラウザで表示できるか確認してみました。
struct ContentView: View {
var body: some View {
if let url = URL(string: "https://(プロジェクト名).web.app/sample.html") {
Link("Firebase Hosting のテスト", destination: url)
}
}
}
アプリ内の Link をクリックして無事外部ブラウザが起動しデプロイしたページが開きました。
data:image/s3,"s3://crabby-images/07f3d/07f3d5921bd448a5dffe4acbb11b5f26de61a8b2" alt=""
以上、Firebase Hosting を使用したWebページの表示手順を紹介しました。
iOS や Android のアプリからも当然アクセスできるので、アプリの利用規約やプライバシーポリシーの表示をWebViewや外部ブラウザで表示することができると思います。
分からなかったのでありがとうございます!