Linee guida di recensione di Android Play Store per IAP
Copia un prompt di configurazione con i passaggi di installazione e la guida markdown completa per questo plugin.
Per ottenere l'approvazione del tuo'app Android su Google Play è necessario rispettare le politiche di Google, soprattutto per le app con acquisti in-app e abbonamenti. Questa guida copre tutto ciò di cui hai bisogno per superare la revisione con successo.
Percorso di rilascio che funziona
Sezione intitolata “Percorso di rilascio che funziona”-
Crea un'app Android firmata in bundle
Le nuove app di Google Play devono essere caricate come un bundle dell'app Android (
.aab), non come un APK di debug caricato manualmente.Mantieni
versionCodeaumenta con ogni caricamento e conserva la chiave di caricamento in modo sicuro se utilizzi Play App Signing.
-
Crea il record dell'app in Console di Play
Se non hai ancora un account di sviluppatore, inizia con iscrizione a Console di PlayPoi, in Home > Crea appseleziona la lingua, tipo di app/gioco, stato gratuito/pagato, indirizzo email di supporto e accetta le dichiarazioni richieste.
Scegli attentamente lo stato gratuito/pagato. Google ti consente di cambiare un'app pagata in gratuita in un secondo momento, ma una volta che un'app è stata offerta gratuitamente, non può essere convertita in pagata.

-
Completa il contenuto dell'app e la lista di archiviazione
Prima della revisione di produzione, completa le dichiarazioni richieste di Console di Play:
- Politica sulla privacy
- Annunci
- Accesso all'app
- Destinatari e contenuti
- Classificazione dei contenuti
- Sicurezza dei dati
- Declarazioni di permessi sensibili, se applicabile
-
Eseguire un test di tracciamento installato su Play
Inizia con Test interni per una QA veloce. Se il tuo account di sviluppatore è un account personale creato dopo il 13 novembre 2023, devi anche completare un test chiuso con almeno 12 tester che hanno optato per l'accesso per 14 giorni consecutivi prima dell'accesso alla produzione.

-
Verifica la fatturazione End-to-End
Installa l'applicazione da Google Play, non da un APK esportato localmente. Poi conferma che:
- I prodotti si caricano correttamente da Play
- La scheda dell'acquisto mostra un compra di test banner per i tester della licenza
- Le entità si sbloccano dopo l'acquisto
- I flussi di ripristino e gestione delle sottoscrizioni funzionano
Requisiti di fatturazione di Google Play
Sezione intitolata “Requisiti di fatturazione di Google Play”Sistema di fatturazione obbligatorio
Sezione intitolata “Sistema di fatturazione obbligatorio”Per beni e servizi digitali, dovete usare il sistema di fatturazione di Google Play: Beni digitali (Dovuto utilizzare Play Billing):
Sottoscrizioni a funzionalità premium
- Moneta in-app o crediti
- Contenuto digitale (libri, musica, video)
- Aggiornamenti di gioco e potenziamenti
- Dischiunci app e livelli premium
- Beni fisici (Non è possibile utilizzare Play Billing):
__CAPGO_KEEP_0__
- Prodotti fisici
- Servizi nel mondo reale
- Donazioni una tantum a organizzazioni non profit
:::note Configurazione abbonamento
Nel Console di Gioco, configura gli abbonamenti Android utilizzando il modello attuale abbonamento -> piano base -> offerta con il modello. In native-purchases, passa l'ID del Piano Base con planIdentifier.
:::
Illeggiamento con acquisti nativi
Sottosezione intitolata “Illeggiamento con acquisti nativi”import { NativePurchases, PURCHASE_TYPE } from '@capgo/native-purchases';
// Ensure billing is available on the deviceconst { 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 Consoleconst 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);Requisiti di trasparenza e divulgazione
Sottosezione intitolata “Requisiti di trasparenza e divulgazione”Informazioni sui Costi a Fronte
Sezione intitolata “Informazioni sui Costi a Fronte”Google Play richiede una chiara disclosure di tutti i costi prima dell'acquisto:
Elementi richiesti:
- Prezzo esatto nella valuta locale dell'utente
- Frequenza di fatturazione (mensile, annuale, ecc.)
- Cosa è incluso nella sottoscrizione
- Costo totale per offerte introduttive
- Quando si verificheranno le spese

Esempio di UI conforme:
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> );}Discarico di Rinnovo Automatico
Sezione intitolata “Discarico di Rinnovo Automatico”Prima che una sottoscrizione si rinnovi automaticamente, Google richiede:
- Avviso chiaro che il rinnovo avverrà
- Ricordo del prezzo
- Accesso facile alla cancellazione
Chiarezza dei prezzi su più piattaforme
Sezione intitolata “Chiarezza dei prezzi su più piattaforme”Se vendi la stessa entità su più piattaforme, mantieni il nome del prodotto, il periodo di fatturazione, i benefici inclusi e il linguaggio di rinnovo allineati, in modo che gli utenti non siano sorpresi.
I prezzi possono differire legittimamente a causa di tasse, valuta locale o economia del negozio, ma l'interfaccia di acquisto non deve mai nascondere queste differenze o suggerire un costo di rinnovo diverso da quello che Google Play caricherà.
Requisiti della politica sulla privacy
Sezione intitolata “Requisiti della politica sulla privacy”Politica sulla privacy obbligatoria
Sezione intitolata “Politica sulla privacy obbligatoria”Se il tuo app include acquisti in-app, devi:
-
Collegamento nella lista dei prodotti di Play Store
- Aggiungi URL della politica sulla privacy nel console di Play
- Deve essere accessibile al pubblico
- Deve essere nella stessa lingua del tuo app
-
Collegamento all'interno dell'app
- Mostra la politica sulla privacy nei impostazioni dell'app
- Mostra prima di raccogliere qualsiasi dato utente
- Fai facilmente scoprire
Esempio di Implementazione:
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> );}Sezione della sicurezza dei dati
Sezione intitolata “Sezione della sicurezza dei dati”Google Play richiede una dettagliata dichiarazione nella sezione della sicurezza dei dati:
Per le App IAP, dichiara:
- Raccolta dei dati relativi alle acquisti
- Indirizzi email (per le ricevute)
- ID dispositivi (per la prevenzione dei frodi)
- Gestione delle informazioni di pagamento
- Dati di analisi di raccolta
La sezione sulla sicurezza dei dati è vincolante per legge. Le dichiarazioni inaccurate possono portare alla rimozione dell'app.
Dichiarazioni del contenuto dell'app
Sottosezione intitolata “Dichiarazioni del contenuto dell'app”La recensione di Google Play non riguarda solo il binario. Prima di una versione di produzione, completa le dichiarazioni in Politiche e programmi > Contenuto dell'app.
Il minimo da revisionare con attenzione:
- Politica sulla privacy: URL pubblico nel Console di Gioco, più un punto di ingresso in-app quando richiesto
- Annunci: Dichiarare se l'app contiene annunci
- Accesso all'app: Inviare le credenziali di accesso ai revisori o una chiara procedura di test se alcune schermate sono bloccate
- Target audience and content: Assicurarsi che il pubblico reale dell'app sia corretto
- Content ratings: Completare il questionario IARC per evitare che l'app venga etichettata come non valutata
- Data Safety: Dichiarare le pratiche di raccolta, condivisione e sicurezza dei dati in modo accurato
Motivi comuni di rifiuto
Sezione intitolata “Motivi comuni di rifiuto”1. Implementazione di fatturazione mancante o errata
Sezione intitolata “1. Implementazione di fatturazione mancante o errata”Perché fallisce:
- Non utilizzare Google Play Billing per beni digitali
- Utilizzare API di fatturazione obsolete
- Implementare soluzioni di pagamento personalizzate per le sottoscrizioni
Prevenzione:
// ✅ 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. Prezzi non chiari o costi nascosti
Sezione intitolata “2. Prezzi non chiari o costi nascosti”Perché Fallisce:
- Il prezzo viene mostrato solo dopo aver cliccato su acquisto
- Frazioni aggiuntive non divulgate in anticipo
- Termini di abbonamento vaghi
Prevenzione:
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. Modelli di abbonamento ingannevoli
Sezione intitolata “3. Modelli di abbonamento ingannevoli”Perché Fallisce:
- Selezione predefinita di opzioni premium
- Nascosta di alternative più economiche
- Rendere difficile la cancellazione
- Urgenza fittizia (“Solo 3 posti disponibili!”)


Prevenzione:
- Mostra tutti i piani di abbonamento in modo uguale
- Fai chiara e accessibile la cancellazione
- Evita i timer di conto alla rovescia o la scarsità fittizia
- Non utilizzare i pattern oscuri per spingere opzioni costose
4. Test non completi
Sezione intitolata “4. Test non completi”Perché fallisce:
- L'app si blocca quando si effettua un acquisto
- I prodotti non si caricano
- La conferma dell'acquisto non viene visualizzata
- Le funzionalità premium non si attivano dopo l'acquisto
- I test sono stati eseguiti solo sui build caricati manualmente anziché su un canale di testing installato tramite Play Store
Prevenzione:
import { NativePurchases, PURCHASE_TYPE } from '@capgo/native-purchases';
// Comprehensive testing before submissionasync 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. Violazioni della politica sulla privacy
Sezione intitolata “5. Violazioni della politica sulla privacy”Perché Fallisce:
- Nessun link alla politica sulla privacy nell'app
- La politica sulla privacy non è accessibile
- La raccolta dei dati non è stata resa nota
- Sezione di sicurezza dei dati non precisa
Prevenzione:
- Aggiungi politica sulla privacy alla lista di Play Store
- Includi link nelle impostazioni dell'app
- Riempisci correttamente la sezione di sicurezza dei dati
- Aggiorna la politica quando si aggiunge una nuova raccolta di dati
Programmi di fatturazione alternativi
Sezione intitolata “Programmi di fatturazione alternativi”I programmi di fatturazione alternativi di Google sono specifici della regione e possono cambiare. Se desideri qualcosa diverso dalla fatturazione standard di Google Play Billing, conferma immediatamente prima dell'implementazione l'eligibilità del mercato, le API richieste e il linguaggio di dichiarazione nella console di Play.
Gestione delle Sottoscrizioni
Sezione intitolata “Gestione delle Sottoscrizioni”Cancellazione Facile
Sezione intitolata “Cancellazione Facile”Gli utenti devono essere in grado di:
- Visualizzare facilmente le sottoscrizioni attive
- Cancellare senza contattare il supporto
- Capire quando ha effetto la cancellazione
Esecuzione:
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> );}Periodo di Grazia per la Cancellazione
Sezione intitolata “Periodo di Grazia per la Cancellazione”Dichiarazione Obbligatoria:
- Quando ha effetto la cancellazione?
- Gli utenti mantengono l'accesso fino a quando non scade il periodo?
- Sono disponibili rimborsi parziali?
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> );}Elenco di controllo pre-invio
Sezione intitolata “Elenco di controllo pre-invio”
-
Verifica l'implementazione fatturazione
- Utilizzo di Google Play Billing (tramite native-purchases)
- Tutti i prodotti di abbonamento creati in Console Play
- Piani base e offerte configurati correttamente
- I prodotti sono attivati e pubblicati
- I prezzi sono impostati per tutti i paesi di destinazione
-
Flussi di acquisto di prova
- Crea un account di licenza di prova
- Installa la build da un tracciato di testing di Play
- Testa ogni livello di abbonamento
- Verifica che i prodotti si caricano correttamente
- Testa la conclusione dell'acquisto
- Conferma il banner di acquisto di prova appare
- Verifica che le funzionalità premium siano sbloccate
- Test la ripristino della sottoscrizione
- Test su più dispositivi
-
Recensisci Tutti i Copioni
- I prezzi sono chiaramente visualizzati prima dell'acquisto
- Tutti i costi sono resi noti in anticipo
- I termini della sottoscrizione sono chiari
- Il processo di cancellazione è spiegato
- Nessuna affermazione ingannevole
-
Contenuto dell'app e Privacy
- La politica sulla privacy è collegata in Console di Gioco
- La politica sulla privacy è accessibile nell'app
- La dichiarazione degli annunci è completata
- Istruzioni di accesso all'app aggiunte se l'app è bloccata
- Sezione della sicurezza dei dati completata con precisione
- Permessi giustificati e documentati
-
Classificazione del contenuto e pubblico
- Compilare il questionario di classificazione del contenuto
- Compilare la sezione del pubblico e del contenuto
- Assicurarsi che la classificazione corrisponda al contenuto reale
- Declinare le vendite in-app nel questionario
-
Preparare la lista della Store
- Descrizione dell'app precisa
- Descrizione breve è entro i 80 caratteri
- Descrizione completa è entro i 4000 caratteri
- Almeno 2 screenshot del telefono caricati
- La grafica di feature 1024x500 caricata
- I screenshot mostrano la versione corrente
- Tutti gli asset richiesti caricati
Timeline di revisione
Sezione intitolata “Timeline di revisione”Accesso alla produzione per nuovi conti personali: Di solito 7 giorni o meno dopo l'invio della richiesta Prima revisione di produzione: Spesso alcuni giorni, a volte più a lungo se sono sollevate domande sulla fatturazione o le politiche Aggiornamenti: Spesso più veloci della prima release, ma comunque revisionati Appelli: Pianifica per diversi giorni e fornisce istruzioni di revisione precise
:::tip Revisioni Continue A differenza di Apple, Google effettua revisioni degli app costantemente. La tua app potrebbe essere pubblicata in qualsiasi momento durante il periodo di revisione, non a un momento fissato. :::
Test prima della sottoscrizione
Sezione intitolata “Test prima della sottoscrizione”Test del Licenziamento
Sezione intitolata “Test del Licenziamento”-
Aggiungi account di test:
- Vai al Console di Gioco
- Impostazioni > Test del licenziamento
- Aggiungi account Gmail per il test
-
Testa nel Sandbox:
import { NativePurchases, PURCHASE_TYPE } from '@capgo/native-purchases';
// Test purchases with license test accountasync 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);}- Banner di verifica del test:
- Quando si effettua l'acquisto con un account di test
- Si dovrebbe vedere la notifica di acquisto 'Test'
- Non si verificano spese reali
Piste di testing interno e chiuso
Sezione intitolata 'Piste di testing interno e chiuso'Prima della versione di produzione:
- Crea un pista di testing interno per una QA veloce o una pista di testing chiusa Segui per una verifica più ampia
- Carica un file firmato
.aabe pubblica il rilascio di testing - Aggiungi indirizzi email degli tester e condividi il link di opt-in
- Fai installare ai tester il build da Google Play
- Verifica che i flussi di acquisto funzionino in modo end-to-end sul build installato su Play
- Se il tuo account di sviluppatore è stato creato dopo il 13 novembre 2023, mantieni almeno 12 tester iscritti a un test chiuso per 14 giorni consecutivi prima di richiedere la produzione
Un build di debug caricato non è un sostituto per un build di testing installato su Play quando si valuta Google Play Billing.
Pratiche Raccomandate per Acquisti Nativi
Sezione intitolata “Pratiche Raccomandate per Acquisti Nativi”Gestisci Tutti gli Stati di Acquisto
Sezione intitolata “Gestisci Tutti gli Stati di Acquisto”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); }}Implementa la ripristino delle acquisti
Sezione intitolata “Implementa la ripristino delle acquisti”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> );}Verifica lo stato della sottoscrizione
Sezione intitolata “Verifica lo stato della sottoscrizione”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); }}Se il tuo app viene rifiutato
Sezione intitolata “Se il tuo app viene rifiutato”Violazioni delle politiche comuni
Sezione intitolata “Violazioni delle politiche comuni”Politica dei pagamenti:
- Non utilizza Google Play Billing
- Termini di abbonamento ingannevoli
- Costi nascosti
Politica dei dati utente:
- Mancanza di politica sulla privacy
- Dichiarazioni di sicurezza dei dati inesatte
- Autorizzazioni eccessive
Passaggi di risoluzione
Sezione intitolata “Passaggi di risoluzione”-
Verifica la Notifica di violazione
- Leggi la politica specifica citata
- Capisci cosa Google ha segnalato
- Verifica gli esempi che hanno fornito
-
Risolve il problema
- Affronta la causa radice, non solo i sintomi
- Testa accuratamente dopo la correzione
- Documenta tutte le modifiche apportate
-
Presenta un'Appello (se applicabile)
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.comPassword: TestPass123Thank you for your consideration.
-
Ripresenta o Aggiorna
- Carica la versione corretta
- Ripresenta per la revisione
- Monitor status in Play Console
Risorse aggiuntive
Sezione intitolata “Risorse aggiuntive”- Centro delle politiche dello sviluppatore di Google Play
- Documentazione di Google Play Billing
- Pratiche migliori per le sottoscrizioni
- Preparare l'app per la revisione
- Requisiti di testing per nuove account personali
- Aiuto di Console Play
Hai bisogno di aiuto esperto?
Sezione intitolata “Hai bisogno di aiuto esperto?”Navigare nella revisione di Store Play può essere complesso, soprattutto quando si devono combinare la conformità dei pagamenti, le dichiarazioni del contenuto dell'app e la configurazione del tracciamento dei test. Se hai bisogno di assistenza personalizzata:
Prenota una chiamata di consultazione con il nostro team per aiuto con:
- Preparazione della recensione completa di Play Store
- Configurazione del tracciato di testing e reclutamento del tester
- Revisione dell'implementazione IAP
- Compliance con la sicurezza dei dati e la privacy
- Risoluzione dei problemi di rifiuto e ricorso
- Processo di sottoscrizione dell'app completa
I nostri esperti hanno guidato centinaia di app attraverso le sottoscrizioni di Play Store riuscite e possono aiutarvi a navigare le attuali richieste.
Supporto
Sezione intitolata “Supporto”Hai bisogno di aiuto con l'implementazione?
- Verifica il Documentazione per le acquisizioni native
- Controlla Guida di testing del sandbox Android
- Visita Supporto dello sviluppatore di Google Play
Continua da qui le linee guida di recensione di Android Play Store per IAP
Sezione intitolata “Continua da qui le linee guida di recensione di Android Play Store per IAP”Se stai utilizzando Linee guida di recensione di Android Play Store per IAP per pianificare la sicurezza e la conformità, connettilo con Utilizzando @capgo/native-purchases per la capacità nativa in Utilizzo di @capgo/native-purchases, Crittografia per il dettaglio di implementazione in Crittografia, Conformità per il dettaglio di implementazione in Conformità, Capgo Scanner di Sicurezza per il flusso di lavoro del prodotto in Capgo Scanner di Sicurezza, e Capgo Sicurezza per il flusso di lavoro del prodotto in Capgo Sicurezza.