Questo documento descrive come eseguire la migrazione dalla Libreria Fatturazione Google Play (PBL) 7 o 8 alla PBL 9 e come integrarla con le nuove funzionalità.
Per un elenco completo delle modifiche nella versione 9.0.0, consulta le note di rilascio.
Panoramica
PBL 9 contiene miglioramenti alle API esistenti e la rimozione delle API precedentemente ritirate. Questa versione della libreria introduce anche un contesto di errore più ricco tramite nuovi codici di risposta secondari.
Compatibilità con le versioni precedenti per l'upgrade di PBL
Per eseguire la migrazione alla Libreria Fatturazione Play 9, devi aggiornare o rimuovere alcuni riferimenti API esistenti dalla tua app, come descritto nelle note di rilascio e più avanti in questa guida alla migrazione.
Eseguire l'upgrade dalla Libreria Fatturazione Play 7 o 8 alla Libreria Fatturazione Play 9
Per eseguire l'upgrade da PBL 7 o 8 a PBL 9:
Aggiorna la versione della dipendenza della libreria Fatturazione Play nel file
build.gradledella tua app.dependencies { def billing_version = "9.1.0" implementation "com.android.billingclient:billing:$billing_version" }Se utilizzi Kotlin, il modulo KTX della Libreria Fatturazione Google Play contiene estensioni Kotlin e supporto delle coroutine che ti consentono di scrivere codice Kotlin idiomatico quando utilizzi la Libreria Fatturazione Google Play. Per includere queste estensioni nel tuo progetto, aggiungi la seguente dipendenza al file
build.gradledella tua app, come mostrato:dependencies { val billing_version = "9.1.0" implementation("com.android.billingclient:billing-ktx:$billing_version") }(Applicabile solo per l'upgrade dalla Libreria Fatturazione Play 7 alla Libreria Fatturazione Play 9). Aggiorna l'implementazione del metodo
queryProductDetailsAsync.È stata apportata una modifica alla firma del metodo
ProductDetailsResponseListener.onProductDetailsResponse, che richiede modifiche alla tua app per l'implementazione diqueryProductDetailsAsync. Per maggiori informazioni, consulta la sezione Mostrare i prodotti disponibili per l'acquisto.Gestisci le API rimosse.
La tabella seguente elenca le API rimosse e le API alternative corrispondenti che devi utilizzare nella tua app.
Esegui l'upgrade da
PBL 9 non supporta più le API elencate nella tabella seguente. Se la tua implementazione utilizza una di queste API rimosse, consulta la tabella per le API alternative corrispondenti.
API precedentemente deprecata rimossa API alternativa da utilizzare API queryPurchaseHistoryAsync Consulta Eseguire query sulla cronologia acquisti. Se utilizzavi queryPurchaseHistoryAsync per determinare l'idoneità alle prove senza costi, ora devi utilizzare ProductDetails.getSubscriptionOfferDetails() per determinare a quali offerte è idoneo un utente. BillingClient.SkuType BillingClient.ProductType. Le costanti del tipo di prodotto INAPP e SUBS rimangono funzionalmente simili alle costanti del tipo di SKU deprecate. SkuDetails ProductDetails. Questo è il nuovo modello di dati che supporta i prodotti una tantum. SkuDetailsParams Utilizza QueryProductDetailsParams con queryProductDetailsAsync. SkuDetailsResponseListener Utilizza ProductDetailsResponseListener con queryProductDetailsAsync. QueryPurchaseHistoryParams - Utilizza queryPurchasesAsync per gli acquisti attivi o in attesa.
- Monitora gli acquisti consumati sui server di backend.
- Utilizza l'API Voided Purchases lato server per gli acquisti annullati o invalidati.
getSkuDetailsList e setSkuDetailsList Utilizza BillingFlowParams.Builder.setProductDetailsParamsList querySkuDetailsAsync queryProductDetailsAsync enablePendingPurchases() (API senza parametri) enablePendingPurchases(PendingPurchasesParams params)
Tieni presente che il metodo enablePendingPurchases() deprecato è funzionalmente equivalente aenablePendingPurchases(PendingPurchasesParams.newBuilder().enableOneTimeProducts().build()).queryPurchasesAsync(String skuType, PurchasesResponseListener listener) queryPurchasesAsync Esegui l'upgrade da
La tabella seguente elenca le API rimosse in PBL 9 e le API alternative corrispondenti che devi utilizzare nella tua app.
API precedentemente deprecata rimossa API alternativa da utilizzare BillingClient.SkuType BillingClient.ProductType. Le costanti del tipo di prodotto INAPP e SUBS rimangono funzionalmente simili alle costanti del tipo di SKU deprecate. SkuDetails ProductDetails. Questo è il nuovo modello di dati che supporta i prodotti una tantum. SkuDetailsParams Utilizza QueryProductDetailsParams con queryProductDetailsAsync. SkuDetailsResponseListener Utilizza ProductDetailsResponseListener con queryProductDetailsAsync. QueryPurchaseHistoryParams - Utilizza queryProductDetailsAsync per gli acquisti attivi o in attesa.
- Monitora gli acquisti consumati sui server di backend.
- Utilizza l'API Voided Purchases lato server per gli acquisti annullati o invalidati.
getSkuDetailsList e setSkuDetailsList Utilizza BillingFlowParams.Builder.setProductDetailsParamsList (Consigliato) Attiva la riconnessione automatica del servizio.
La Libreria Fatturazione Play può tentare di ristabilire automaticamente la connessione al servizio se viene effettuata una chiamata API mentre il servizio è disconnesso. Per saperne di più, vedi Attivare la riconnessione automatica del servizio.
Gestisci i nuovi codici di risposta secondaria.
Il valore BillingResult restituito da
launchBillingFlow()ora include un campo del codice di risposta secondario. Questo campo verrà compilato solo in alcuni casi per fornire un motivo più specifico del mancato caricamento. Il campo della risposta secondaria può avere i seguenti valori:PAYMENT_DECLINED_DUE_TO_INSUFFICIENT_FUNDS- Restituito quando i fondi dell'utente sono inferiori al prezzo dell'articolo che sta tentando di acquistare.USER_INELIGIBLE- Errore restituito quando l'utente non soddisfa i requisiti di idoneità configurati per un'offerta di abbonamento.NO_APPLICABLE_SUB_RESPONSE_CODE: il valore predefinito, restituito quando non è applicabile nessun altro codice di risposta secondario.
Passaggio di migrazione: aggiorna la gestione dei risultati
PurchasesUpdatedListenero equivalente per riconoscere e rispondere a questi codici di risposta secondaria specifici per offrire una migliore esperienza utente. Ad esempio, ti chiede di correggere i metodi di pagamento o mostra un messaggio di errore specifico.Rilevamento della riclassificazione dei codici di errore.
Nei casi in cui l'app Play Store è bloccata dal sistema (ad esempio, nella modalità bambino personalizzata dall'OEM), il codice di risposta di PBL è cambiato da
ERRORaBILLING_UNAVAILABLE.Passaggio di migrazione: assicurati che la logica di gestione degli errori tenga conto di questa modifica e non si basi sulla ricezione di un errore generico in questi scenari specifici.
Gestisci il supporto di valori null per
DeveloperProvidedBillingDetails.getLinkUri().Se utilizzi
DeveloperProvidedBillingDetailsnell'ambito di un'integrazione di pagamenti esterni,getLinkUri()ora è@Nullable.Passaggio di migrazione: per gestire questa modifica in modo sicuro, assicurati che il codice di integrazione gestisca sia i valori
nullsia le stringhe vuote ("") del metodoDeveloperProvidedBillingDetails.getLinkUri()prima di analizzare o avviare gli intent del browser. Ad esempio:Kotlin
val linkUri = details.linkUri if (!linkUri.isNullOrEmpty()) { val intent = Intent(Intent.ACTION_VIEW, linkUri.toUri()) context.startActivity(intent) }
Java
String linkUri = details.getLinkUri(); if (!android.text.TextUtils.isEmpty(linkUri)) { Intent intent = new Intent(Intent.ACTION_VIEW, Uri.parse(linkUri)); context.startActivity(intent); }Modifiche facoltative.
Supporta gli acquisti in attesa per i piani prepagati. Per maggiori informazioni, vedi Gestire gli abbonamenti e le transazioni in attesa.
Abbonamenti con rate virtuali. Per ulteriori informazioni, consulta la sezione Integrazione degli abbonamenti rateali.