ページの作成
親となるページを選択してください。
親ページに紐づくページを子ページといいます。
例: 親=スポーツ, 子1=サッカー, 子2=野球
子ページを親ページとして更に子ページを作成することも可能です。
例: 親=サッカー, 子=サッカーのルール
親ページはいつでも変更することが可能なのでとりあえず作ってみましょう!
| この記事の要点 |
|
事前準備: Google Cloud Console
- Google Cloud Console にアクセス
- 新規プロジェクト作成 (または既存プロジェクト選択)
- 左メニュー API とサービス → ライブラリ
- YouTube Data API v3 を検索 → 有効化
- 認証情報 → + 認証情報を作成:
- API キー: 公開データ読み取り用。すぐ発行
- OAuth クライアント ID: ユーザー認可が必要な操作用。同意画面の設定が必要
- API キーは HTTP リファラ制限 / IP 制限を設定してリーク対策
主要エンドポイント
| エンドポイント | 用途 | クォータコスト |
|---|---|---|
videos.list | 動画情報取得(指定 ID) | 1 |
search.list | キーワード検索 | 100 |
channels.list | チャンネル情報 | 1 |
playlists.list | 再生リスト一覧 | 1 |
playlistItems.list | 再生リスト内動画 | 1 |
commentThreads.list | コメント取得 | 1 |
videos.insert | 動画アップロード | 1,600 |
liveBroadcasts.list | ライブ配信 | 1 |
JavaScript (ブラウザ) からの呼び出し
シンプルな HTTP リクエスト
# API キーで動画情報取得
curl "https://www.googleapis.com/youtube/v3/videos?part=snippet,statistics&id=dQw4w9WgXcQ&key=YOUR_API_KEY"
# 検索
curl "https://www.googleapis.com/youtube/v3/search?part=snippet&q=Laravel&type=video&maxResults=5&key=YOUR_API_KEY"
# チャンネル情報
curl "https://www.googleapis.com/youtube/v3/channels?part=snippet,statistics&forHandle=@GoogleDevelopers&key=YOUR_API_KEY"
PHP からの呼び出し
setDeveloperKey('YOUR_API_KEY');
$youtube = new Google\Service\YouTube($client);
// 検索
$response = $youtube->search->listSearch('snippet', [
'q' => 'Laravel チュートリアル',
'type' => 'video',
'maxResults' => 10,
'order' => 'viewCount',
'regionCode' => 'JP',
]);
foreach ($response->items as $item) {
echo $item->id->videoId . ' — ' . $item->snippet->title . "\n";
}
// 動画詳細
$videos = $youtube->videos->listVideos('snippet,statistics,contentDetails', [
'id' => 'dQw4w9WgXcQ',
]);
foreach ($videos->items as $v) {
echo $v->snippet->title . "\n";
echo "views: " . $v->statistics->viewCount . "\n";
echo "duration: " . $v->contentDetails->duration . "\n"; // ISO 8601 PT4M13S
}
part パラメータの主な値
| part 値 | 含まれる情報 |
|---|---|
snippet | タイトル、説明、サムネ、公開日、チャンネル名 |
statistics | 視聴数、いいね数、コメント数 |
contentDetails | 動画長さ (ISO 8601)、画質、字幕有無、年齢制限 |
status | 公開状態、組込許可、ライセンス |
player | 埋込用 iframe HTML |
topicDetails | Wikipedia トピック関連 |
カンマ区切りで複数指定: part=snippet,statistics,contentDetails。必要なものだけにしてクォータ節約。
クォータ管理
- デフォルト 10,000 ユニット/日。日本時間 16:00 / 17:00 (PST 0:00) にリセット
search.listは 1 リクエスト = 100 ユニット。100 回叩くと枯渇- 不足する場合は クォータ拡張申請(フォーム提出 → 数週間レビュー)
- 節約テク:
fieldsパラメータで返却フィールドを絞る、結果キャッシュ、ID 既知ならvideos.list(コスト 1)に切替
# fields パラメータ例 — 必要だけ取り出す
?part=snippet,statistics
&fields=items(id,snippet/title,statistics/viewCount)
OAuth が必要な操作
自分のチャンネルへの動画アップロード、プレイリスト編集、コメント投稿は API キーでは不可。OAuth 2.0 認可フローが必要です:
setClientId('CLIENT_ID');
$client->setClientSecret('CLIENT_SECRET');
$client->setRedirectUri('http://localhost/oauth2callback.php');
$client->addScope(Google\Service\YouTube::YOUTUBE_UPLOAD);
if (!isset($_GET['code'])) {
header('Location: ' . $client->createAuthUrl());
exit;
}
$token = $client->fetchAccessTokenWithAuthCode($_GET['code']);
$client->setAccessToken($token);
// これで OAuth 必須 API も呼べる
$youtube = new Google\Service\YouTube($client);
// $youtube->videos->insert(...)
FAQ
Q: API キーが漏洩した
A: Cloud Console から即座に削除し、新規発行。リファラ制限 / IP 制限を必ず設定。フロントエンド埋込は最小限の権限のみ。
Q: search.list でフィルタしたら結果がおかしい
A: order=relevance がデフォルト。再現性が必要なら order=date + 日付フィルタ。publishedAfter / publishedBefore は RFC 3339 形式。
Q: クォータが枯渇したらどうなる
A: quotaExceeded エラーで全リクエストが失敗。翌日リセットまで待つか、別プロジェクトの API キーを発行。長期的にはキャッシュ / バックエンド集約が必須。
ページの作成
親となるページを選択してください。
親ページに紐づくページを子ページといいます。
例: 親=スポーツ, 子1=サッカー, 子2=野球
子ページを親ページとして更に子ページを作成することも可能です。
例: 親=サッカー, 子=サッカーのルール
親ページはいつでも変更することが可能なのでとりあえず作ってみましょう!
同階層のページ
- YouTube Data API (v3)
- Twitter API
- Facebook API
- Google Trends
- Google Custom Search API
- App Store Connect API
- Revit API
人気ページ
- 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
コメントを削除してもよろしいでしょうか?