タイトル: Google OAuth 2.0
SEOタイトル: Google OAuth 2.0 認証の実装方法
| この記事の要点 |
|---|
|
本稿はGoogle OAuth 2.0を使用した認証(ログイン)方法について説明します。
前提
・Googleアカウントを所有している。
・本稿ではPHPを用いて実装例を記載します。
同意画面の入力
Google APIsにてプロジェクトを作成してください。
続けて、以下の画像を参考に「認証情報」→「OAuth同意画面」を選択して、必要な情報を入力して下さい。

OAuthクライアントIDの取得
以下の画像を参考に「認証情報」→「認証情報を作成」→「OAuthクライアントID」を指定します。

1.アカウント情報入力画面の呼び出し
PHPでの実装に入ります。
まずは大まかな流れを説明します。
1.「Googleアカウントでログイン」といったボタンを作り、「https://accounts.google.com/o/oauth2/auth」でアカウント情報入力画面を呼び出す。
2.アカウント情報を入力する。
3.リダイレクト先にcodeパラメータが渡されるので、それを基に「https://accounts.google.com/o/oauth2/token」を呼び出して、アクセストークンを取得する。
4.アクセストークを基に「https://www.googleapis.com/oauth2/v1/userinfo」を呼び出して、IDや名前、メールアドレスといったユーザー情報を取得する。
5.ユーザー情報をテーブルやせs格納して、ログイン情報を管理する。(ここはアプリケーションの運用方法によって異なるので、詳細は省略)
では、上から順に説明します。
1.アカウント情報入力画面を呼び出す。
適当なボタンを作成して、「https://accounts.google.com/o/oauth2/auth」を呼び出しましょう。
text.php
|
Googleアカウントでログイン
|
auth.php
|
const GOOGLE_AUTH_URL = 'https://accounts.google.com/o/oauth2/auth'; /* |
2.アカウント情報
アカウント認証画面が開かれます。
こちらはGoogleで用意された画面なのでアカウント情報を入力するだけです。
3.アクセストークンの取得 および 4.ユーザー情報の取得
リダイレクト先に渡されるcodeパラメータを基にアクセストークンを取得し、更にアクセストークンを基にユーザー情報を取得します。
アクセストークンを取得する際に指定するリダイレクト先は、自身のphpファイルを指定すればよいです。
redirect.php
|
const GOOGLE_TOKEN_URL = 'https://accounts.google.com/o/oauth2/token'; //パラメータ /* //POST送信 //レスポンス取得
|
以下の様なレスポンスが表示されるので、テーブルやセッションに突っ込んで管理しましょう。
|
Array |