< Back

Firebase x OGPの決定版【Dynamic Links】

Firebase x OGPの決定版はDynamic Linksだと思うけど異論ある?

異論は受け付けます。

まず最初に私が紹介する方法は何種類か存在するOGPでも一種類だけしか使えないっぽいので、それ以外だと以下のようなやり方が一番いいと思います。

Vue.jsとFirebaseでOGP画像生成系のサービスを爆速で作ろう

HostingにアクセスしたときにFunctionsをいい感じに使えるのは us-central1 のみですので、その詳細は、この記事 Cloud Functions を使用した動的コンテンツの配信とマイクロサービスのホスティング重要: Firebase Hosting は、us-central1 でのみ Cloud Functions をサポートします。 のあたりを見るといいと思います。

試してほしい。

Twitterのカードバリデーターはこちら
OGP試せるやつです!!

Dynamic Linksの使い方

yk@yk for-qiita % firebase init

     ######## #### ########  ######## ########     ###     ######  ########
     ##        ##  ##     ## ##       ##     ##  ##   ##  ##       ##
     ######    ##  ########  ######   ########  #########  ######  ######
     ##        ##  ##    ##  ##       ##     ## ##     ##       ## ##
     ##       #### ##     ## ######## ########  ##     ##  ######  ########

You're about to initialize a Firebase project in this directory:

  /Users/yk/workspace/for-qiita

? Which Firebase CLI features do you want to set up for this folder? Press Space to select features, then Enter to confirm your choices. Hosting: Configure and deploy Firebase Hosting s
ites

=== Project Setup

First, let's associate this project directory with a Firebase project.
You can create multiple project aliases by running firebase use --add, 
but for now we'll just set up a default project.

? Please select an option: Create a new project
i  If you want to create a project in a Google Cloud organization or folder, please use "firebase projects:create" instead, and return to this command when you've created the project.
? Please specify a unique project id (warning: cannot be modified afterward) [6-30 characters]:
 for-qiita-ogp
? What would you like to call your project? (defaults to your project ID) 
✔ Creating Google Cloud Platform project
✔ Adding Firebase resources to Google Cloud Platform project

🎉🎉🎉 Your Firebase project is ready! 🎉🎉🎉

Project information:
   - Project ID: for-qiita-ogp
   - Project Name: for-qiita-ogp

Firebase console is available at
https://console.firebase.google.com/project/for-qiita-ogp/overview
i  Using project for-qiita-ogp (for-qiita-ogp)

=== Hosting Setup

Your public directory is the folder (relative to your project directory) that
will contain Hosting assets to be uploaded with firebase deploy. If you
have a build process for your assets, use your build's output directory.

? What do you want to use as your public directory? public
? Configure as a single-page app (rewrite all urls to /index.html)? Yes
✔  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配下に index.html が作られていたらOK

yk@yk for-qiita % ls public 
index.html

このままデプロイします。

yk@yk for-qiita % firebase deploy

=== Deploying to 'for-qiita-ogp'...

i  deploying hosting
i  hosting[for-qiita-ogp]: beginning deploy...
i  hosting[for-qiita-ogp]: found 1 files in public
✔  hosting[for-qiita-ogp]: file upload complete
i  hosting[for-qiita-ogp]: finalizing version...
✔  hosting[for-qiita-ogp]: version finalized
i  hosting[for-qiita-ogp]: releasing new version...
✔  hosting[for-qiita-ogp]: release complete

✔  Deploy complete!

Project Console: https://console.firebase.google.com/project/for-qiita-ogp/overview
Hosting URL: https://for-qiita-ogp.firebaseapp.com

最初のカードバリデーターはこんな感じ。OGP用のデータがないのでOGPが表示されません。

スクリーンショット 2020-03-11 3.06.01.png

次は自分専用のリンクURLを発行します。適当に forqiita を入力しました。

スクリーンショット 2020-03-11 3.06.59.png

次は適当にポチポチしていたら、ダイナミックリンクの設定ができます。

スクリーンショット 2020-03-11 3.07.37.png

ここに自分のサイトへのリンクを貼り

スクリーンショット 2020-03-11 3.08.48.png

そして 5番が重要で、OGPのタイトルとか猫の画像とかをはります。

スクリーンショット 2020-03-11 3.09.51.png

なんということでしょう。猫の画像がOGPとして表示されました!

スクリーンショット 2020-03-11 3.10.10.png

このURLを試してみたください。

さて後2つ猫画像用意したので、猫好きさんは次のURLも試してくれるでしょう😺

さて、 https://forqiita.page.link/6eZ4 にアクセスしたら https://for-qiita-ogp.firebaseapp.com/ にリダイレクトされます。その仕組を追うために NetworkPreserve log で遷移後までログを追ってみたのですが、 300 とかでhttpリダイレクトでもなく、 meta とか JavaScript とかでもなさそう?だったので、詳しいかたリダイレクトのレスポンスとか確認してほしいです。

スクリーンショット 2020-03-11 3.20.37.png

そんな感じです。

.