コンテンツにジャンプ

Android Play Store IAPのレビュー規定

Google Play での Android アプリの承認には、特にアプリ内課金やサブスクリプションがあるアプリの場合、Google のポリシーへの準拠が必要です。このガイドでは、レビューを通過するために必要なすべての内容をカバーしています。

  1. 署名Androidアプリバンドルを作成する

    新しいGoogle Playアプリは、Androidアプリバンドル(.aab)としてアップロードする必要があります。デバッグのためのsideloaded APKではありません。

    __CAPGO_KEEP_0__の versionCode __CAPGO_KEEP_0__が増加し、Play App Signingのアップロードキーを安全に保管するようにしてください。

    Androidアプリバンドルフロー

  2. Play Consoleでアプリレコードを作成する

    開発者アカウントがまだない場合は、 Play Consoleのサインアップから始めてください。次に、 ホーム > アプリを作成で、言語、アプリ/ゲームの種類、無料/有料のステータス、サポートメール、必要な宣言を承認します。

    無料/有料設定を慎重に選択してください。 Google は、有料アプリを無料に変更することを許可していますが、無料で提供されたアプリは有料に切り替えることはできません。

    Play Console でアプリを作成する

  3. アプリの内容とストアのリストを完了する

    生産性のあるレビュー前に、必要なPlay Consoleの申告を完了する:

    • プライバシーポリシー
    • 広告
    • アプリへのアクセス
    • 対象読者とコンテンツ
    • コンテンツの評価
    • データの安全性
    • 関連する許可の申告、必要に応じて
  4. Play-インストールされたテストトラックを実行する

    迅速なQAのために内部テストから始めます。開発者アカウントが、2023年11月13日以降に作成された個人アカウントの場合、生産アクセス前に、少なくとも12人のオプトインテスターと共に、14日連続で閉鎖テストを完了する必要があります。 __CAPGO_KEEP_0__ Play Consoleの内部テスト 請求の終端までの検証 Google Playからアプリをインストールせず、ローカルにエクスポートされたAPKからインストールしないでください。次に、次のことを確認してください:

    Playから正しく製品が読み込まれる

  5. 購入シートに、__CAPGO_KEEP_0__のテスト購入の表示が見られる

    __CAPGO_KEEP_0__

    • __CAPGO_KEEP_0__
    • __CAPGO_KEEP_0__ __CAPGO_KEEP_0__ __CAPGO_KEEP_0__
    • __CAPGO_KEEP_0__が購入された後、特典は解除されます。
    • __CAPGO_KEEP_0__とサブスクリプション管理フローの機能が正常に動作します。

Google Play 販売要件

「Google Play 販売要件」

必須の販売システム

「必須の販売システム」

デジタル商品やサービスを販売する場合、 あなたはGoogle Playの販売システムを使用する必要があります。 デジタル商品(Play 販売を使用する必要があります):

プレミアム機能へのサブスクリプション

  • インゲーム通貨またはクレジット
  • __CAPGO_KEEP_0__
  • デジタルコンテンツ (ebook、音楽、動画)
  • ゲームアップグレードとパワーアップ
  • アプリのアンロックとプレミアム階層

物理商品 (Play Billingを使用できない):

  • 物理商品
  • 現実世界のサービス
  • 非営利団体への一時的な寄付

:::note サブスクリプション設定 Play Consoleで、Androidサブスクリプションを設定するには、現在の サブスクリプション -> 基本プラン -> オファー モデルを使用します。 native-purchases、Base Plan IDを planIdentifier. :::

import { NativePurchases, PURCHASE_TYPE } from '@capgo/native-purchases';
// Ensure billing is available on the device
const { isBillingSupported } = await NativePurchases.isBillingSupported();
if (!isBillingSupported) throw new Error('Google Play Billing not available');
// Fetch subscription products (Store data is required—never hardcode pricing)
const { products } = await NativePurchases.getProducts({
productIdentifiers: ['premium_monthly', 'premium_yearly'],
productType: PURCHASE_TYPE.SUBS,
});
// Plan identifiers are the Base Plan IDs you create in Google Play Console
const transaction = await NativePurchases.purchaseProduct({
productIdentifier: 'premium_monthly',
planIdentifier: 'monthly-plan', // REQUIRED on Android, ignored on iOS
productType: PURCHASE_TYPE.SUBS,
});
console.log('Purchase token for server validation:', transaction.purchaseToken);

Google Playでは購入前にすべてのコストを明確に開示することが求められます。

必要な要素:

  • ユーザーのローカル通貨で正確な価格
  • 請求頻度(月額、年額など)
  • サブスクリプションに含まれるもの
  • 導入オファーの合計コスト
  • 料金の請求時期

UI デザインのベスト プラクティス

適合する UI の例:

function SubscriptionCard({ product }) {
return (
<div className="subscription-card">
<h3>{product.title}</h3>
{/* Show intro offer if available */}
{product.introductoryPrice && (
<div className="intro-offer">
<p className="intro-price">{product.introductoryPriceString}</p>
<p className="intro-period">
for {product.introductoryPricePeriod}
</p>
</div>
)}
{/* Regular price */}
<div className="regular-price">
<p className="price">{product.priceString}</p>
<p className="period">per {product.subscriptionPeriod}</p>
</div>
{/* Clear description */}
<p>{product.description}</p>
{/* Renewal terms */}
<p className="terms">
Renews automatically. Cancel anytime in Google Play.
</p>
<button onClick={() => handlePurchase(product)}>
Subscribe Now
</button>
</div>
);
}

サブスクリプションが自動更新される前に、Google は次のことを要求します:

  • 更新が行われることを明確に示す通知
  • 料金の詳細
  • キャンセルに簡単にアクセスできるようにする

クロスプラットフォーム価格の明確性

「クロスプラットフォーム価格の明確性」のセクション

同じエンターティメントを複数のプラットフォームで販売する場合、製品名、請求期間、付与される利益、更新の言語を同期して、ユーザーが驚かれないようにしてください。

税金、ローカル通貨、またはストアの経済状況によって価格が異なる場合もありますが、購入UIはそれらの差異を隠すことはできず、Google Playが請求する更新コストと異なる再生コストを暗示することはできません。

Play Store リストにリンク

  1. Play ConsoleにプライバシーポリシーURLを追加

    • __CAPGO_KEEP_0__
    • __CAPGO_KEEP_0__
    • __CAPGO_KEEP_0__
  2. アプリ内でリンク

    • アプリ設定でプライバシーポリシーを表示
    • ユーザーデータを収集する前に表示
    • 容易に発見できるように

実装例:

function SettingsScreen() {
const openPrivacyPolicy = () => {
window.open('https://yourapp.com/privacy', '_blank');
};
const openTerms = () => {
window.open('https://yourapp.com/terms', '_blank');
};
return (
<div>
<h2>Settings</h2>
<button onClick={openPrivacyPolicy}>
Privacy Policy
</button>
<button onClick={openTerms}>
Terms of Service
</button>
<button onClick={() => NativePurchases.manageSubscriptions()}>
Manage Subscriptions
</button>
</div>
);
}

データセキュリティセクション

データセキュリティセクション

Google Playでは、データセキュリティセクションで詳細な披露が必要です:

IAPアプリの場合、次のように宣言してください:

  • 購入履歴の収集
  • 請求書のためのメールアドレス
  • 不正防止のためのデバイスID
  • 決済情報の処理
  • 分析データの収集

__CAPGO_KEEP_0__

アプリ内容の申告

__CAPGO_KEEP_1__

ビルドファイルだけではありません。生産用のリリース前に、申告を完了してください。 ポリシーとプログラム > アプリ内容.

注意して確認する最低限の内容:

  • プライバシーポリシー: Play Console の公開 URL、必要に応じてアプリ内エントリポイント
  • 広告: アプリが広告を含むかどうかを宣言する
  • アプリへのアクセス: ゲートされたスクリーンがあれば、レビュアーにワークイングクレデンシャルまたは明確なテストパスを提供する
  • 対象読者とコンテンツ: アプリの実際の読者と一致させる
  • コンテンツの評価: アプリが評価されていないとマークされないように IARC の質問紙を完了する
  • データの安全性: データの収集、共有、セキュリティの実践を正確に宣言する

なぜ失敗するのか

  • デジタル商品のためにGoogle Play Billingを使用していない
  • 古い請求APIを使用している
  • サブスクリプションのカスタム支払いソリューションを実装している

防止対策:

// ✅ Correct: Use native-purchases (uses Google Play Billing)
await NativePurchases.purchaseProduct({
productIdentifier: 'premium_monthly',
planIdentifier: 'monthly-plan',
productType: PURCHASE_TYPE.SUBS,
});
// ❌ Wrong: Custom payment processor for subscriptions
// await CustomPayment.charge(user, 9.99);

2. 不明確な価格設定または非公開コスト

セクション「2. 不明確な価格設定または非公開コスト」

なぜ失敗するのか:

  • 購入ボタンをクリックするまで価格が表示されない
  • 事前に非公開の追加料金
  • 不明確なサブスクリプション条件

防止対策:

function PurchaseScreen({ product }) {
return (
<div>
{/* Show ALL costs upfront */}
<h2>Premium Subscription</h2>
<div className="pricing">
<p className="price">{product.priceString}/month</p>
<p className="taxes">Taxes may apply based on location</p>
</div>
<div className="features">
<h3>Includes:</h3>
<ul>
<li>Ad-free experience</li>
<li>Unlimited cloud storage</li>
<li>Priority support</li>
</ul>
</div>
<div className="terms">
<p>
Subscription renews automatically unless cancelled at least
24 hours before the end of the current period.
</p>
<p>
Manage or cancel in Google Play Subscriptions.
</p>
</div>
<button onClick={handlePurchase}>
Start Subscription
</button>
</div>
);
}

3. 欺瞞的なサブスクリプションパターン

セクション「3. 欺瞞的なサブスクリプションパターン」

なぜ失敗するのか:

  • プレミアムオプションを事前に選択する
  • 安い代替案を隠す
  • キャンセルを難しくする
  • 「残り3つだけ!」などの偽の緊急性

説明のベストプラクティス

マーケティングガイドライン

予防:

  • すべてのサブスクリプションレベルを同等に表示する
  • キャンセルを明確かつアクセス可能にする
  • カウントダウンタイマーや偽の不足を避ける
  • 高価なオプションを押し付けるためにダークパターンを使わない

なぜ失敗するのか:

  • 購入時にアプリがクラッシュする
  • 製品が読み込まれない
  • 購入確認が表示されない
  • プレミアム機能が購入後にアンロックされない
  • テストはサイドロードされたビルドのみで行われていたが、Playストアからインストールしたテストトラックでは行われていなかった

防止策:

import { NativePurchases, PURCHASE_TYPE } from '@capgo/native-purchases';
// Comprehensive testing before submission
async function testPurchaseFlow() {
try {
// 1. Test product loading
const { products } = await NativePurchases.getProducts({
productIdentifiers: ['premium_monthly', 'premium_yearly'],
productType: PURCHASE_TYPE.SUBS,
});
console.log('✓ Products loaded:', products.length);
// 2. Test purchase flow
const transaction = await NativePurchases.purchaseProduct({
productIdentifier: 'premium_monthly',
planIdentifier: 'monthly-plan',
productType: PURCHASE_TYPE.SUBS,
});
console.log('✓ Purchase completed', transaction.transactionId);
// 3. Verify entitlements
const { purchases } = await NativePurchases.getPurchases({
productType: PURCHASE_TYPE.SUBS,
});
if (
purchases.some(
(purchase) =>
purchase.productIdentifier === 'premium_monthly' &&
['PURCHASED', '1'].includes(purchase.purchaseState ?? '') &&
purchase.isAcknowledged,
)
) {
console.log('✓ Premium features unlocked');
}
// 4. Test restore
await NativePurchases.restorePurchases();
console.log('✓ Restore works');
} catch (error) {
console.error('✗ Test failed:', error);
}
}

5. プライバシーポリシーの違反

セクション「5. プライバシーポリシーの違反」

なぜ失敗するのか:

  • アプリ内にプライバシーポリシーへのリンクがない
  • プライバシーポリシーへのアクセスができない
  • データ収集の情報が明らかになっていない
  • データセキュリティのセクションが正確ではない

対策:

  • プレイストアのアプリリストにプライバシーポリシーを追加する
  • アプリの設定内にリンクを含める
  • データセキュリティのセクションを正確に記入する
  • 新しいデータ収集を追加した際にポリシーを更新する

Googleの代替請求プログラムは地域によって異なり、変更される可能性があります。標準のGoogle Play Billing以外のものを使用したい場合は、実装前にPlay Consoleで、正確な市場の適格性、必要なAPI、および披露言語を確認してください。

ユーザーは次のことができる必要があります。

  • アクティブなサブスクリプションを簡単に表示する
  • サポートに連絡することなくキャンセルする
  • キャンセルの効果時期を理解する

実装:

import { NativePurchases } from '@capgo/native-purchases';
function ManageSubscriptionButton() {
const openManagement = async () => {
try {
// Opens Google Play subscription management
await NativePurchases.manageSubscriptions();
} catch (error) {
// Fallback to direct URL
const playStoreUrl = 'https://play.google.com/store/account/subscriptions';
window.open(playStoreUrl, '_blank');
}
};
return (
<button onClick={openManagement}>
Manage Subscription in Google Play
</button>
);
}

キャンセル期間

キャンセル期間

必要な披露:

  • キャンセルが有効になるのはいつ?
  • ユーザーは期間終了までアクセスを維持する?
  • 部分的な返金は利用可能?
function CancellationInfo() {
return (
<div className="cancellation-info">
<h3>Cancellation Policy</h3>
<ul>
<li>Cancel anytime in Google Play</li>
<li>Access continues until end of billing period</li>
<li>No refunds for partial periods</li>
<li>Resubscribe anytime to regain access</li>
</ul>
<button onClick={() => NativePurchases.manageSubscriptions()}>
Manage in Google Play
</button>
</div>
);
}

提出前にチェックリスト

提出前にチェックリスト

提出前にチェックリスト

  1. __CAPGO_KEEP_0__

    • Google Play Billingを使用する (native-purchasesを介して)
    • すべてのPlay Consoleで作成されたサブスクリプション製品
    • 基本プランとオファーが正しく設定されている
    • 製品が有効化され、公開されている
    • すべての対象国に価格が設定されている
  2. 購入フローのテスト

    • ライセンステストアカウントを作成する
    • Playテストトラックからビルドをインストールする
    • 各サブスクリプション階層をテストする
    • 製品が正しくロードされている
    • 購入の完了をテストする
    • 購入確認 テスト購入 バナーが表示される
    • プレミアム機能がアンロックされる
    • サブスクリプションの復元
    • 複数のデバイスでテスト
  3. すべてのコピーを確認

    • 購入前に価格が明確に表示される
    • すべての料金が事前に明示される
    • サブスクリプションの条件が明確
    • キャンセルプロセスが説明されている
    • 誤解を招くような主張がない
  4. アプリコンテンツとプライバシー

    • プライバシーポリシーはPlay Consoleでリンクされています
    • プライバシーポリシーはアプリ内でアクセス可能です
    • 広告の申告が完了しました
    • アプリがブロックされている場合にアプリへのアクセス方法が追加されました
    • データセーフティセクションは正確に完了しました
    • 許可された権限が正当化され、文書化されています
  5. コンテンツレーティングとターゲットアウディエンス

    • コンテンツレーティングの全問答が完了しました
    • ターゲットアウディエンスとコンテンツの全問答が完了しました
    • レーティングが実際のコンテンツと一致するようにしてください
    • 質問紙にインアプリ購入を宣言してください
  6. ストア リストの準備

    • アプリの説明が正確
    • 短い説明は80文字以内
    • フル説明は4000文字以内
    • 少なくとも2つの電話画面のスクリーンショットがアップロードされている
    • 1024x500の特徴グラフィックがアップロードされている
    • スクリーンショットは現在のバージョンを表示している
    • 必要なすべてのアセットがアップロードされている

新しい個人アカウントの生産アクセス: 通常、申請後7日以内に 初回リリースの確認 請求やポリシーの質問が生じた場合、しばしば数日、あるいは長くなる場合があります。 アップデート 初回リリースよりも速い場合もありますが、依然として確認が行われます。 アピール 数日間を計画し、正確な修正とレビュアーへの指示を提供してください。

ローリングレビュー Appleと異なり、Googleはアプリを継続的にレビューします。アプリはレビュー期間中いつでも公開される可能性があり、固定時間ではなくいつでもです。

提出前にテスト

提出前にテスト

ライセンステスト

ライセンステスト
  1. テストアカウントを追加

    • Play Console に移動する
    • 設定 > ライセンステスト
    • テスト用にGmailアカウントを追加する
  2. テスト環境でテストする:

import { NativePurchases, PURCHASE_TYPE } from '@capgo/native-purchases';
// Test purchases with license test account
async function testInSandbox() {
const { isBillingSupported } = await NativePurchases.isBillingSupported();
if (!isBillingSupported) {
console.error('Billing not supported in this environment');
return;
}
// Fetch products (returns test pricing when using a license tester)
const { products } = await NativePurchases.getProducts({
productIdentifiers: ['premium_monthly'],
productType: PURCHASE_TYPE.SUBS,
});
console.log('Test products:', products);
// Make test purchase (no charge)
const transaction = await NativePurchases.purchaseProduct({
productIdentifier: 'premium_monthly',
planIdentifier: 'monthly-plan',
productType: PURCHASE_TYPE.SUBS,
});
console.log('Test purchase complete:', transaction.transactionId);
}
  1. テストバナーを検証する:
    • テストアカウントで購入する場合
    • 「テスト購入」通知を確認する
    • 実際の料金は発生しない

内部テストとクローズドテスト

「内部テストとクローズドテスト」セクション

本番リリース前:

  1. テスト用アプリを __CAPGO_KEEP_0__ 内部テスト用のトラックを作成して、高速なQAを実行するか、または より広範なテスト用のトラックを作成して、 テスト用のリリースをアップロードして公開する
  2. テスターのメールアドレスを追加して、オプトイン用のリンクを共有する .aab Google Playからビルドをインストールするようにテスターに指示する
  3. Playでインストールされたビルドで、Google Play Billingの購入フローの動作を端端まで確認する
  4. あなたの個人開発者アカウントが2023年11月13日以降に作成された場合、少なくとも12人のテスターを14日間連続して閉鎖テストにオプトインさせておく必要があります。そうしないと、生産環境への申請が却下される可能性があります。
  5. Google Play Billingの検証のために、サイドロードされたデバッグビルドは、Playでインストールされたテスト用ビルドの代わりではありません。
  6. 内部テスト用のトラックを作成して、高速なQAを実行するか、またはより広範なテスト用のトラックを作成して、

テスト用のリリースをアップロードして公開する

ネイティブ購入のベストプラクティス

ネイティブ購入のベストプラクティス

すべての購入状態を処理する

すべての購入状態を処理する
import { NativePurchases, PURCHASE_TYPE } from '@capgo/native-purchases';
async function handlePurchase(productId: string, planIdentifier?: string) {
try {
setLoading(true);
const transaction = await NativePurchases.purchaseProduct({
productIdentifier: productId,
planIdentifier,
productType: planIdentifier ? PURCHASE_TYPE.SUBS : PURCHASE_TYPE.INAPP,
});
console.log('Purchase token:', transaction.purchaseToken ?? transaction.receipt);
// Success - check entitlements from the store
const { purchases } = await NativePurchases.getPurchases({
productType: planIdentifier ? PURCHASE_TYPE.SUBS : PURCHASE_TYPE.INAPP,
});
const isOwned = purchases.some(
(purchase) =>
purchase.productIdentifier === productId &&
(purchase.purchaseState === 'PURCHASED' || purchase.purchaseState === '1') &&
purchase.isAcknowledged,
);
if (isOwned) {
unlockPremiumFeatures();
showSuccess('Premium activated!');
}
} catch (error: any) {
// Handle specific error cases
switch (error.code) {
case 'USER_CANCELLED':
// User backed out - no error needed
console.log('Purchase cancelled');
break;
case 'ITEM_ALREADY_OWNED':
// They already own it - restore instead
showInfo('You already own this! Restoring...');
await NativePurchases.restorePurchases();
break;
case 'ITEM_UNAVAILABLE':
showError('This subscription is currently unavailable. Please try again later.');
break;
case 'NETWORK_ERROR':
showError('Network error. Please check your connection and try again.');
break;
default:
showError('Purchase failed. Please try again.');
console.error('Purchase error:', error);
}
} finally {
setLoading(false);
}
}

購入を復元する

購入を復元する
import { NativePurchases, PURCHASE_TYPE } from '@capgo/native-purchases';
function RestorePurchasesButton() {
const [loading, setLoading] = useState(false);
const handleRestore = async () => {
setLoading(true);
try {
await NativePurchases.restorePurchases();
const { purchases } = await NativePurchases.getPurchases({
productType: PURCHASE_TYPE.SUBS,
});
const hasSubscription = purchases.some(
(purchase) => purchase.productType === 'subs' && purchase.isAcknowledged,
);
if (hasSubscription) {
unlockPremiumFeatures();
showSuccess('Subscriptions restored!');
return;
}
// Check one-time unlocks if needed
const { purchases: iaps } = await NativePurchases.getPurchases({
productType: PURCHASE_TYPE.INAPP,
});
const hasInApp = iaps.some((purchase) => purchase.productIdentifier === 'premium_unlock');
if (hasInApp) {
unlockPremiumFeatures();
showSuccess('Previous purchases restored!');
return;
}
showInfo('No previous purchases found.');
} catch (error) {
showError('Failed to restore purchases. Please try again.');
} finally {
setLoading(false);
}
};
return (
<button onClick={handleRestore} disabled={loading}>
{loading ? 'Restoring...' : 'Restore Purchases'}
</button>
);
}

サブスクリプションのステータスを確認する

コピー
import { NativePurchases, PURCHASE_TYPE } from '@capgo/native-purchases';
async function checkSubscriptionStatus() {
try {
const { purchases } = await NativePurchases.getPurchases({
productType: PURCHASE_TYPE.SUBS,
});
const subscription = purchases.find(
(purchase) =>
purchase.productIdentifier === 'premium_monthly' &&
(purchase.purchaseState === 'PURCHASED' || purchase.purchaseState === '1') &&
purchase.isAcknowledged,
);
if (!subscription) {
showPaywall();
return;
}
console.log('Subscription active:', {
productId: subscription.productIdentifier,
expiresAt: subscription.expirationDate,
willRenew: subscription.willCancel === false,
purchaseToken: subscription.purchaseToken,
});
unlockPremiumFeatures();
} catch (error) {
console.error('Failed to check subscription:', error);
}
}

一般的なポリシー違反

一般的なポリシー違反

支払いポリシー:

  • Google Play Billing を使用していない
  • 誤解を招くサブスクリプション条項
  • 非表示のコスト

ユーザーデータポリシー:

  • プライバシーポリシーが欠落している
  • データセキュリティの正確な宣言が欠落している
  • 過剰な権限

解決策のステップ

解決手順
  1. 違反通知を確認する

    • 特定の規定を読む
    • Googleが何を指摘したのかを理解する
    • 提供された例を確認する
  2. 問題を修正する

    • 症状だけではなく根本原因を解決する
    • 修正後、徹底的にテストする
    • 行った変更をすべてドキュメントする
  3. 申し立てを行う (必要に応じて)

    説明と申し立てのプロセス

    Subject: Policy Violation Appeal - [App Name]
    Dear Google Play Review Team,
    I have received notification that my app violates [Policy X.Y].
    I have made the following changes to comply:
    1. [Specific change made]
    2. [Specific change made]
    3. [Specific change made]
    The updated version [version number] addresses all concerns raised.
    Test account for verification:
    Email: test@example.com
    Password: TestPass123
    Thank you for your consideration.

    ドキュメントのリクエスト例

  4. 再提出または更新

    • 修正版をアップロード
    • 再提出のためのレビュー
    • Play Consoleでステータスを監視

Play Store のレビューをナビゲートすることは複雑です。特に、請求の適合性、App のコンテンツの宣言、テストトラックの設定を組み合わせる必要がある場合です。専門的な助けが必要な場合:

チームとオンラインカウントを予約してください の助けが必要な場合:

  • Play Store のレビューの準備が完了する
  • テストトラックの設定とテスターの募集
  • IAP の実装のレビュー
  • データの安全性とプライバシーの適合性
  • 却下のトラブルシューティングとアピール
  • アプリの完全な提出プロセス

数百のアプリを成功したPlayストアの提出に導き、現在の要件を乗り切るのに役立つ専門家がいます。

実装に必要な手助けが必要ですか?