Googleログイン認証をWebサイトに組み込む
Googleログイン認証をAngularを使ったWebサイトに組み込む手順を解説します。
動作イメージ
Google API クライアント ID を取得する
Google API クライアント ID を取得するの手順に従い、Google API クライアント IDを取得します。
👇プロジェクトを作成
data:image/s3,"s3://crabby-images/9e43b/9e43be400b1533bc87522b0fb21273d667c20371" alt="image"
data:image/s3,"s3://crabby-images/24090/24090b00d5759e02413c33420fc629740c85e543" alt="image"
👇認証情報(OAuthクライアントID)を作成
data:image/s3,"s3://crabby-images/59cba/59cbadaa1849fe72d916489984fbc13c29909e5e" alt="image"
👇同意画面を設定
data:image/s3,"s3://crabby-images/9d66e/9d66e942740f7fc6da3349943f8ef313a96149a0" alt="image"
👇UserType:外部を指定し作成
data:image/s3,"s3://crabby-images/cfc86/cfc8652688656e4d8faf4d765322ae4c6256afec" alt="image"
👇アプリ情報を設定
data:image/s3,"s3://crabby-images/66dda/66ddac88ea7c14f57e8b36a69798b53211d86480" alt="image"
data:image/s3,"s3://crabby-images/0d94e/0d94e8ba029d93453abf766341dec29a75cb6339" alt="image"
👇スコープを追加
data:image/s3,"s3://crabby-images/f3710/f3710284d40464bfa56b79c4ff5725156e82d9ec" alt="image"
data:image/s3,"s3://crabby-images/727fb/727fbd16cb693ed9e1fb1a41bdc8f1b0f6a773e3" alt="image"
👇アプリを公開
data:image/s3,"s3://crabby-images/6e429/6e429e54d32830f331839e1cc56638fb7519ed3d" alt="image"
👇認証情報(OAuthクライアントID)を作成
data:image/s3,"s3://crabby-images/6554a/6554a5562d8899fe835752f446878235dfb51c45" alt="image"
data:image/s3,"s3://crabby-images/99b8f/99b8f8830e0b8465db9c548f19ad160fec19b75c" alt="image"
👇クライアントID/クライアントシークレットをコピー
data:image/s3,"s3://crabby-images/51533/51533199042d7571a7da85400fdfa950250ff0aa" alt="image"
Angular 構成の準備
以降の手順は以下記事の内容を前提とします。
Angularのインストール~最小限構成の設定手順
Google認証の実装
Google に認証リクエストを送信する
👇認証リクエストを送信
https://accounts.google.com/o/oauth2/v2/auth?response_type=code&client_id=[クライアントID]&scope=openid%20email%20profile&redirect_uri=http%3A//localhost%3A4200&nonce=20240308&access_type=offline
👇リダイレクトされたURLパラメータから認証トークンを取得します
ngOnInit(): void {
let tmp_code = this.getParamValue("code");
}
getParamValue(key: string): string{
let ret_value = "";
if(location.search.substring(1) != ""){
var pair = location.search.substring(1).split('&');
for(var i=0;pair[i];i++) {
var kv = pair[i].split('=');
if(kv[0] == key){
ret_value = kv[1];
break;
}
}
}
return ret_value;
}