ページの作成
親となるページを選択してください。
親ページに紐づくページを子ページといいます。
例: 親=スポーツ, 子1=サッカー, 子2=野球
子ページを親ページとして更に子ページを作成することも可能です。
例: 親=サッカー, 子=サッカーのルール
親ページはいつでも変更することが可能なのでとりあえず作ってみましょう!
| この記事の要点 |
|
全体の流れ
- Amazon アソシエイト・プログラムへ登録 (サイト or SNS チャネルが必要)
- 審査通過 (180 日以内に 3 件以上の適格売上を出すと本承認)
- アソシエイト管理画面から PA-API 用認証情報を発行
- Access Key ID / Secret Access Key / パートナータグの 3 点セットを取得
- SDK や HTTP クライアントから署名付きリクエストで API 呼出
Step 1: Amazon アソシエイト登録
- Amazon アソシエイト にアクセス
- 通常の Amazon アカウントでログイン
- アカウント情報・支払先・サイトまたは SNS の URL を入力
- 運営サイトの内容についての質問に回答(ジャンル・収益化方法)
- アソシエイト ID (例: xxxxxx-22) を選ぶ → 登録完了
登録直後は仮登録状態。180 日以内に 3 件以上の適格売上が必要です。これを満たさないとアソシエイト ID が無効化されます。
Step 2: PA-API 用の認証情報発行
- アソシエイト管理画面にログイン
- 上部メニューから ツール → Product Advertising API
- 認証情報を追加する ボタンをクリック
- 「認証情報を追加しました」画面で:
- アクセスキー (Access Key ID)
- シークレットキー (Secret Access Key) — この画面でしか確認できない。閉じると二度と取り出せず再発行のみ
- 認証情報を CSV でダウンロードボタンで保存推奨
- パートナータグはアソシエイト ID (例
yourid-22) と同じ
取得する 3 つの値
| 項目 | 例 | 用途 |
|---|---|---|
| Access Key ID | AKIAxxxxxxxxxxxxxxxx | 公開可。リクエスト識別 |
| Secret Access Key | wJalrXUtnFEMI/K7MDENG/... | 絶対秘匿。署名生成用 |
| パートナータグ | yourid-22 | リクエストに必須。報酬の紐付け |
マーケットプレースも指定が必要です:
| マーケットプレース | ホスト | リージョン |
|---|---|---|
| 日本 | webservices.amazon.co.jp | us-west-2 |
| 米国 | webservices.amazon.com | us-east-1 |
| 英国 | webservices.amazon.co.uk | eu-west-1 |
| ドイツ | webservices.amazon.de | eu-west-1 |
Step 3: SDK でテストリクエスト
# PHP SDK
composer require amzn/paapi5-php-sdksetAccessKey('YOUR_ACCESS_KEY');
$config->setSecretKey('YOUR_SECRET_KEY');
$config->setHost('webservices.amazon.co.jp');
$config->setRegion('us-west-2');
$apiInstance = new DefaultApi(new Client(), $config);
$req = new SearchItemsRequest();
$req->setSearchIndex('All');
$req->setKeywords('Kindle');
$req->setItemCount(3);
$req->setPartnerTag('yourid-22');
$req->setPartnerType(PartnerType::ASSOCIATES);
$req->setResources(['ItemInfo.Title', 'Offers.Listings.Price']);
try {
$resp = $apiInstance->searchItems($req);
foreach ($resp->getSearchResult()->getItems() as $item) {
echo $item->getASIN() . ' — '
. $item->getItemInfo()->getTitle()->getDisplayValue() . "\n";
}
} catch (ApiException $e) {
echo "Error: " . $e->getMessage() . "\n";
echo $e->getResponseBody();
}
180 日 / 3 件売上ルール
PA-API が「審査制」と言われる根拠です:
- アソシエイト登録初日から180 日 (約 6 ヶ月)がカウント開始
- この期間中に 3 件以上の適格売上(自分以外の購入者によるアソシエイトリンク経由購入)が必要
- 達成すると本登録され、PA-API が継続利用可能に
- 未達成だとアソシエイト ID 失効 → PA-API も使用不可
- 失効後の再登録は可能。アカウントは Amazon 利用そのものとは別
新規開設後に PA-API を使う場合の戦略:
- 最初は 商品リンクツール (PA-API 不要) で売上 3 件を作る
- 3 件達成後に PA-API 認証情報を発行 → 開発開始
- その後はリクエスト数に応じてレート制限が緩和される
キー漏洩時の対処
- アソシエイト管理画面 → PA-API → 該当キーを削除
- 新規キーを発行
- git にコミットしてしまった場合は
git filter-repoやBFG Repo-Cleanerで履歴から除去 - 環境変数 or
.env管理に変更(.gitignore必須)
レート制限
- 初期: 1 リクエスト/秒、合計 8,640 リクエスト/日
- 過去 30 日の発送済売上 1 円ごとに +1 リクエスト/日増加
- つまり売上を上げるほどリクエスト枠が増える仕組み
- 枠を超えると
TooManyRequests (429)エラー
FAQ
Q: シークレットキーをメモし忘れた
A: 一度も表示できない。該当キーを削除して新規発行するしかない。発行直後に必ず CSV ダウンロードか .env に保存を。
Q: パートナータグを複数持てる?
A: 可能。サイト別に siteA-22 / siteB-22 等を発行し、リクエストの PartnerTag で切替。レポートも分かれる。
Q: 売上 3 件が間に合わない
A: 期限内達成は努力義務。失効しても再申請は可能だが、再度 180 日カウントから。SNS 流入や知人購入はカウント対象になることが多い (規約は要確認)。
ページの作成
親となるページを選択してください。
親ページに紐づくページを子ページといいます。
例: 親=スポーツ, 子1=サッカー, 子2=野球
子ページを親ページとして更に子ページを作成することも可能です。
例: 親=サッカー, 子=サッカーのルール
親ページはいつでも変更することが可能なのでとりあえず作ってみましょう!
子ページ
子ページはありません
同階層のページ
人気ページ
- 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
コメントを削除してもよろしいでしょうか?