ページの作成
親となるページを選択してください。
親ページに紐づくページを子ページといいます。
例: 親=スポーツ, 子1=サッカー, 子2=野球
子ページを親ページとして更に子ページを作成することも可能です。
例: 親=サッカー, 子=サッカーのルール
親ページはいつでも変更することが可能なのでとりあえず作ってみましょう!
| この記事の要点 |
|
エラーの正体
Laravel Socialite や古い OAuth クライアントが、Google ログイン後にユーザー情報を取得しようとして廃止された Google+ APIを呼んで失敗します:
GuzzleHttp\Exception\ClientException:
Client error: `GET https://www.googleapis.com/plus/v1/people/me?prettyPrint=false`
resulted in a `404 Not Found` response:
{
"error": {
"code": 404,
"message": "Method not found.",
"status": "NOT_FOUND"
}
}
Google+ サービスは 2019 年 3 月 7 日に完全終了。これに伴い API (plus.googleapis.com, www.googleapis.com/plus/v1/...) も応答停止しました。古いライブラリは plus.profile.emails.read スコープと /plus/v1/people/me を叩く設計のままだとこのエラーが出ます。
対処1: Laravel Socialite を 5.x にアップグレード
Socialite 4.x は内部で Google+ API を呼んでいる。5.0 以降は People API ベースに刷新済:
# composer.json
composer require laravel/socialite:^5.0
# 古い場合
composer update laravel/socialite
# 確認
composer show laravel/socialite
# versions : * v5.x// config/services.php
'google' => [
'client_id' => env('GOOGLE_CLIENT_ID'),
'client_secret' => env('GOOGLE_CLIENT_SECRET'),
'redirect' => env('GOOGLE_REDIRECT_URI'),
],
// routes/web.php
Route::get('/auth/google', [AuthController::class, 'redirect']);
Route::get('/auth/google/callback', [AuthController::class, 'callback']);
// AuthController
public function redirect()
{
return Socialite::driver('google')->redirect();
}
public function callback()
{
$user = Socialite::driver('google')->user();
// 5.x では People API 経由で取得
$email = $user->getEmail();
$name = $user->getName();
$avatar = $user->getAvatar();
$id = $user->getId();
// ログイン処理 ...
}
対処2: Google OpenID Connect の userinfo を使う
Socialite 以外のライブラリでも、OpenID Connect 標準の userinfo endpoint を使えば確実:
use GuzzleHttp\Client;
$http = new Client();
$res = $http->get('https://openidconnect.googleapis.com/v1/userinfo', [
'headers' => [
'Authorization' => 'Bearer ' . $accessToken,
],
]);
$user = json_decode($res->getBody(), true);
/*
{
"sub": "1234567890",
"name": "山田 太郎",
"given_name": "太郎",
"family_name": "山田",
"picture": "https://lh3.googleusercontent.com/...",
"email": "taro@example.com",
"email_verified": true,
"locale": "ja"
}
*/
// 必要なスコープ
// openid email profile
対処3: Google People API を使う
use GuzzleHttp\Client;
$http = new Client();
$res = $http->get('https://people.googleapis.com/v1/people/me', [
'headers' => [
'Authorization' => 'Bearer ' . $accessToken,
],
'query' => [
'personFields' => 'names,emailAddresses,photos',
],
]);
$people = json_decode($res->getBody(), true);
/*
{
"resourceName": "people/1234567890",
"names": [{"displayName": "山田太郎", ...}],
"emailAddresses": [{"value": "taro@example.com", "metadata": {...}}],
"photos": [{"url": "https://...", ...}]
}
*/
// People API を使うには Google Cloud Console で
// "People API" を有効化する必要あり
スコープの修正
| 旧スコープ (廃止) | 新スコープ (有効) |
|---|---|
https://www.googleapis.com/auth/plus.login | openid |
https://www.googleapis.com/auth/plus.me | profile |
https://www.googleapis.com/auth/plus.profile.emails.read | email |
https://www.googleapis.com/auth/userinfo.profile | profile (今も有効) |
https://www.googleapis.com/auth/userinfo.email | email (今も有効) |
OAuth 同意画面の確認
- Google Cloud Console を開く:
https://console.cloud.google.com/apis/credentials/consent - OAuth 同意画面 → スコープ → plus.* 系を削除
email/profile/openidのみ残す- People API を使う場合は API ライブラリで「People API」を有効化
- クライアント側のスコープ指定も合わせて修正
Socialite カスタムスコープ指定
return Socialite::driver('google')
->scopes(['openid', 'profile', 'email'])
->with(['prompt' => 'select_account'])
->redirect();
// People API も合わせて呼ぶ場合
return Socialite::driver('google')
->scopes([
'openid', 'profile', 'email',
'https://www.googleapis.com/auth/contacts.readonly',
])
->redirect();
関連エラー
| エラー | 原因 | 対処 |
|---|---|---|
idpiframe_initialization_failed | Google Sign-In JS の廃止 (2023/09) | Google Identity Services (GIS) ライブラリへ移行 |
invalid_scope: plus.login | 廃止スコープ指定 | 上表の新スコープに変更 |
Method not found | plus API 呼び出し | People API or OIDC userinfo へ |
403 PERMISSION_DENIED | People API 未有効化 | Cloud Console で有効化 |
FAQ
Q: 既存ユーザーの Google ID は引き継げる?
A: sub (subject) は id として継続使用可。plus.me の id と OIDC の sub は同じ値です。
Q: Socialite を上げたくない
A: Socialite 4.x で動かすには内部の GoogleProvider を継承してエンドポイントを差し替えるパッチが必要。5.x へのアップグレードが圧倒的に楽。
Q: Firebase Auth でも同様?
A: Firebase Auth は内部で OIDC を使うため影響なし。Firebase SDK の古いバージョンで plus.* を要求するパターンがあれば SDK 更新で解消。
ページの作成
親となるページを選択してください。
親ページに紐づくページを子ページといいます。
例: 親=スポーツ, 子1=サッカー, 子2=野球
子ページを親ページとして更に子ページを作成することも可能です。
例: 親=サッカー, 子=サッカーのルール
親ページはいつでも変更することが可能なのでとりあえず作ってみましょう!
子ページはありません
- Client error: POST https://accounts.google.com/o/oauth2/token
- Client error: GET https://www.googleapis.com/plus/v1/people/me?prettyPrint=false
人気ページ
- 1 Eclipseで「サーバーに追加または除去できるリソースがありません。」の原因と対処法
- 2 tomcat の起動 / 停止ログと catalina.log・catalina.out の違い
- 3 JavaScript base URL 取得方法|window.location.origin と SSR/Node.js 対応
- 4 YouTube Data API v3 エラー一覧|403/400/404 の主要原因と切り分け
- 5 Spring Frameworkのアノテーション一覧
- 6 Laravel エラー一覧|500/Blade/DB 接続/ルーティングの代表エラー
- 7 3Dグラフィックスとは|モデリング/レンダリング/主要ソフトウェア (Blender / Maya)
- 8 【Spring】@Valueアノテーションとは
- 9 CATALINA_HOME の確認方法 (Linux / Mac)
- 10 【Spring】@Autowiredアノテーションとは
最近更新/作成されたページ
- Laravel キャッシュクリア完全ガイド(cache:clear / config:clear / 2026-05-18 07:42:07
- プロジェクトの作成と削除 2026-05-18 07:42:07
- インストール直後にNetbeansが反応しない 2026-05-18 07:42:07
- 動画やチャンネルの検索 2026-05-18 07:42:07
- APIキー取得方法 2026-05-18 07:42:07
- チャンネル情報の取得 2026-05-18 07:42:07
- API 入門 — Web API(REST / GraphQL / gRPC / 2026-05-18 07:42:07
- インストール(eclipseプラグイン) 2026-05-18 07:42:07
- Laravel「Dotenv values containing spaces must be surrounded 2026-05-18 07:42:07
- エラー一覧 2026-05-18 07:42:07
- curl: (51) SSL: certificate subject name '~' does not match 2026-05-18 07:42:07
- インストール方法(Windows版) 2026-05-18 07:42:07
- JSONから配列に変換 2026-05-18 07:42:07
- 処理を一定時間待つ 2026-05-18 07:42:07
- A non well formed numeric value encountered 2026-05-18 07:42:07
コメントを削除してもよろしいでしょうか?