Informacje o wersji Biblioteki płatności w Google Play

Ten dokument zawiera informacje o wersjach Biblioteki płatności w Google Play.

Wersja 8.1.0 Biblioteki płatności w Google Play (6.11.2025)

Dostępne są już wersja 8.1.0 Biblioteki płatności w Google Play i rozszerzenia Kotlin.

Podsumowanie zmian

  • Zawieszone subskrypcje

    Do metody BillingClient.queryPurchasesAsync() dodano nowy parametr, który umożliwia uwzględnianie zawieszonych subskrypcji podczas wysyłania zapytań o subskrypcje. Zawieszone subskrypcje są nadal przypisane do użytkownika, ale nie są aktywne, ponieważ użytkownik wstrzymał subskrypcję lub odrzucono formę płatności za odnowienie.

    Obiekt Purchase zwrócony w obiekcie nasłuchującym będzie zwracać wartość isSuspended() = true w przypadku wszystkich zawieszonych subskrypcji. W takim przypadku nie należy przyznawać dostępu do kupionej subskrypcji, tylko skierować użytkownika do centrum subskrypcji, gdzie może on zarządzać formami płatności lub wstrzymać subskrypcję, aby ją ponownie aktywować.

  • Aktualizacje subskrypcji:

    • Obiekt BillingFlowParams.ProductDetailsParams ma teraz metodę setSubscriptionProductReplacementParams(), w której możesz określić informacje o zastąpieniu na poziomie produktu.

    • Obiekt SubscriptionProductReplacementParams ma dwie metody ustawiające:

      • setOldProductId: stary produkt, który ma zostać zastąpiony produktem w bieżącej ProductDetails.
      • setReplacementMode: jest to tryb zastępowania na poziomie produktu. Tryby są zasadniczo takie same jak SubscriptionUpdateParams, ale mapowanie wartości zostało zaktualizowane. Wprowadziliśmy nowy tryb wymiany KEEP_EXISTING, który umożliwia zachowanie dotychczasowego harmonogramu płatności za produkt.
    • SubscriptionUpdateParams setSubscriptionReplacementMode zostanie wycofana. Zamiast tego użyj zasady SubscriptionProductReplacementParams.setReplacementMode.

  • Zaktualizowano minSdkVersion do wersji 23.

  • Włączono interfejsy API zamówień w przedsprzedaży dla produktów kupowanych raz

    Interfejs ProductDetails.oneTimePurchaseOfferDetails.getPreorderDetails() API, który pobiera szczegóły zamówienia w przedsprzedaży, jest już dostępny.

  • Biblioteka płatności w Google Play obsługuje teraz Kotlin w wersji 2.2.0.

Wydanie Biblioteki płatności w Google Play w wersji 8.0.0 (30.06.2025)

Wersja 8.0.0 Biblioteki płatności w Google Play i rozszerzenia Kotlin są już dostępne.

Podsumowanie zmian

  • Elementy w aplikacji będą teraz nazywane produktami kupowanymi raz.

  • Wiele opcji zakupu i ofert w przypadku produktów kupowanych raz.

    Możesz teraz mieć wiele opcji zakupu i ofert dla produktów kupowanych raz. Zapewnia to elastyczność w sposobie sprzedaży produktów i ułatwia zarządzanie nimi.

  • Ulepszyliśmy metodę queryProductDetailsAsync().

    Przed wersją PBL 8.0.0 metoda queryProductDetailsAsync() nie zwracała produktów, których nie można było pobrać. Może to być spowodowane tym, że produktu nie znaleziono lub nie ma ofert dostępnych dla użytkownika. W przypadku PBL w wersji 8.0.0 niepobrane produkty są zwracane z nowym kodem stanu na poziomie produktu, który zawiera informacje o niepobranych produktach. Pamiętaj, że zmienił się podpis funkcji ProductDetailsResponseListener.onProductDetailsResponse(), co wymaga wprowadzenia zmian w aplikacji. Więcej informacji znajdziesz w sekcji Przetwarzanie wyniku.

  • Automatyczne ponowne łączenie z usługą.

    Nowy parametr BillingClient.Builder.enableAutoServiceReconnection() builder umożliwia programistom włączenie automatycznego ponownego łączenia z usługą, co upraszcza zarządzanie połączeniami, ponieważ automatycznie obsługuje ponowne łączenie z usługą płatności w Google Play i eliminuje konieczność ręcznego wywoływania startConnection() w przypadku rozłączenia usługi. Więcej informacji znajdziesz w artykule Automatyczne przywracanie połączenia.

  • Kody odpowiedzi podrzędnych dla metody launchBillingFlow().

    Obiekt BillingResult zwracany przez interfejs launchBillingFlow() będzie teraz zawierać pole kodu podrzędnej odpowiedzi. To pole będzie wypełniane tylko w niektórych przypadkach, aby podać bardziej szczegółowy powód niepowodzenia. W przypadku PBL 8.0.0 w sytuacji, gdy środki użytkownika są mniejsze niż cena produktu, który próbuje kupić, zwracany jest kod podrzędny PAYMENT_DECLINED_DUE_TO_INSUFFICIENT_FUNDS.

  • Usunięto metodę queryPurchaseHistory().

    Metoda queryPurchaseHistory(), która była wcześniej oznaczona jako przestarzała, została usunięta. Więcej informacji o tym, jakich alternatywnych interfejsów API używać, znajdziesz w artykule Sprawdzanie historii zakupów.

  • Usunięto metodę querySkuDetailsAsync().

    Metoda querySkuDetailsAsync(), która była wcześniej oznaczona jako wycofana, została usunięta. Zamiast niej używaj funkcji queryProductDetailsAsync.

  • Usunięto metodę BillingClient.Builder.enablePendingPurchases().

    Metoda enablePendingPurchases() bez parametrów, która była wcześniej oznaczona jako wycofana, została usunięta. Zamiast tego użyj zasady enablePendingPurchases(PendingPurchaseParams params). Pamiętaj, że wycofany atrybut enablePendingPurchases() jest funkcjonalnie równoważny atrybutowi enablePendingPurchases(PendingPurchasesParams.newBuilder().enableOneTimeProducts().build()).

  • Usunięto przeciążoną metodę queryPurchasesAsync(), która przyjmuje argument skuType.

    Metoda queryPurchasesAsync(String skuType, PurchasesResponseListener listener), która była wcześniej oznaczona jako przestarzała, została usunięta. Możesz też użyć polecenia queryPurchasesAsync(QueryPurchasesParams queryPurchasesParams, PurchasesResponseListener listener).

Wersja 7.1.1 Biblioteki płatności w Google Play (3.10.2024)

Wersja 7.1.1 Biblioteki płatności w Google Play i rozszerzenia Kotlin są już dostępne.

Poprawki błędów

Wersja 7.1.0 Biblioteki płatności w Google Play (19.09.2024)

Dostępne są już wersja 7.1.0 Biblioteki płatności w Google Play i rozszerzenia Kotlin.

Podsumowanie zmian

  • Ulepszone bezpieczeństwo wątków związane ze stanem połączenia i zarządzaniem nim.
  • Wprowadzono częściowe zmiany w kodach odpowiedzi [BillingResult][billing-result] na potrzeby testowania, które zostały w pełni udostępnione w Bibliotece płatności w Play w wersji 7.1.1. Aby przetestować integrację za pomocą tej funkcji, musisz przejść na Bibliotekę płatności Play w wersji 7.1.1. Występuje błąd, który ma wpływ tylko na aplikacje, w których [włączono testowanie zastąpień rozliczeń][enable-billing-overrides-testing], i nie wpływa na zwykłe użytkowanie. Więcej informacji znajdziesz w artykule Testowanie kodów odpowiedzi.BillingResult [billing-result]: /reference/com/android/billingclient/api/BillingResult [enable-billing-overrides-testing]: /google/play/billing/test-response-codes#enable-billing-overrides-testing

Wydanie Biblioteki płatności w Google Play w wersji 7.0.0 (14.05.2024)

Dostępna jest już wersja 7.0.0 Biblioteki płatności w Google Play i rozszerzenia Kotlin.

Podsumowanie zmian

Wersja 6.2.1 Biblioteki płatności w Google Play (16.04.2024)

Wersja 6.2.1 Biblioteki płatności w Google Play i rozszerzenia Kotlin są już dostępne.

Podsumowanie zmian

Wersja 6.2.0 Biblioteki płatności w Google Play (6.03.2024)

Wersja 6.2.0 Biblioteki płatności w Google Play i rozszerzenia Kotlin są już dostępne.

Podsumowanie zmian

Wersja 6.1.0 Biblioteki płatności w Google Play (14.11.2023)

Dostępna jest już wersja 6.1.0 Biblioteki płatności w Google Play i rozszerzenia Kotlin.

Podsumowanie zmian

Wydanie Biblioteki płatności w Google Play w wersji 6.0.1 (22.06.2023)

Wersja 6.0.1 Biblioteki płatności w Google Play i rozszerzenia Kotlin są już dostępne.

Podsumowanie zmian

Zaktualizuj Bibliotekę płatności w Play, aby była zgodna z Androidem 14.

Wydanie Biblioteki płatności w Google Play w wersji 6.0 (10.05.2023)

Wersja 6.0.0 Biblioteki płatności w Google Play i rozszerzenia Kotlin są już dostępne.

Podsumowanie zmian

  • Dodaliśmy nowy wyliczenie ReplacementMode, aby zastąpić wyliczenie ProrationMode.

    Pamiętaj, że ProrationMode jest nadal dostępny ze względu na zgodność z wcześniejszymi rozwiązaniami.

  • Usunięto identyfikator zamówienia w przypadku zakupów PENDING.

    Wcześniej identyfikator zamówienia był zawsze tworzony, nawet jeśli zakup był w stanie oczekiwania. Od wersji 6.0.0 identyfikator zamówienia nie będzie tworzony w przypadku zakupów oczekujących. W przypadku tych zakupów identyfikator zamówienia zostanie wypełniony po przeniesieniu zakupu do stanu PURCHASED.

  • Usunięto metody queryPurchaseslaunchPriceConfirmationFlow.

    Metody queryPurchaseslaunchPriceConfirmationFlow, które wcześniej były oznaczone jako wycofane, zostały usunięte z Biblioteki Płatności Google Play w wersji 6.0.0. Deweloperzy powinni używać znacznika queryPurchasesAsync zamiast znacznika queryPurchases. Alternatywy dla launchPriceConfirmationFlow znajdziesz w artykule Zmiany cen.

  • Dodano nowy kod odpowiedzi na błąd sieci.

    Od wersji 6.0.0 Biblioteki dodano nowy kod odpowiedzi na błąd sieci:NETWORK_ERROR. Ten kod jest zwracany, gdy wystąpi błąd z powodu problemu z połączeniem sieciowym. Te błędy połączenia sieciowego były wcześniej zgłaszane jako SERVICE_UNAVAILABLE.

  • Zaktualizowano SERVICE_UNAVAILABLE i SERVICE_TIMEOUT.

    Od wersji 6.0.0 biblioteki PBL błędy spowodowane przekroczeniem limitu czasu przetwarzania będą zwracane jako SERVICE_UNAVAILABLE zamiast obecnego SERVICE_TIMEOUT.

    W starszych wersjach PBL to zachowanie nie ulega zmianie.

  • Usunięto:SERVICE_TIMEOUT

    Od wersji PBL 6.0.0 wartość SERVICE_TIMEOUT nie będzie już zwracana. Poprzednie wersje Biblioteki płatności w Play będą nadal zwracać ten kod.

  • Dodaliśmy dodatkowe logowanie.

    Wersja 6 biblioteki Płatności Google Play zawiera dodatkowe rejestrowanie, które zapewnia wgląd w korzystanie z interfejsu API (np. powodzenie i niepowodzenie) oraz problemy z połączeniem z usługą. Te informacje będą używane do zwiększania wydajności Biblioteki płatności w Google Play i zapewniania lepszej pomocy w przypadku błędów.

Wersja 5.2.1 Biblioteki płatności w Google Play (22.06.2023)

Wersja 5.2.1 Biblioteki płatności w Google Play i rozszerzenia Kotlin są już dostępne.

Podsumowanie zmian

Zaktualizuj Bibliotekę płatności w Play, aby była zgodna z Androidem 14.

Wersja 5.2 Biblioteki płatności w Google Play (6.04.2023)

Wersja 5.2.0 Biblioteki płatności w Google Play i rozszerzenia Kotlin są już dostępne.

Podsumowanie zmian

Wydanie biblioteki Płatności w Google Play w wersji 5.1 (31.10.2022)

Wersja 5.1.0 Biblioteki płatności w Google Play i rozszerzenia Kotlin są już dostępne.

Ta wersja zawiera następujące zmiany:

Podsumowanie zmian

Wydanie Biblioteki płatności w Google Play w wersji 5.0 (11.05.2022)

Wersja 5.0.0 Biblioteki płatności w Google Play i rozszerzenia Kotlin są już dostępne.

Ta wersja zawiera następujące zmiany:

Podsumowanie zmian

  • Wprowadziliśmy nowy model subskrypcji, w tym nowe jednostki, które umożliwiają tworzenie wielu ofert dla jednego produktu subskrypcyjnego. Więcej informacji znajdziesz w przewodniku po migracji.
  • Dodano BillingClient.queryProductDetailsAsync() w miejsce BillingClient.querySkuDetailsAsync().
  • Dodaliśmy setIsOfferPersonalized() metodę spełniania wymagań dotyczących ujawniania informacji o spersonalizowanych cenach w UE. Więcej informacji o korzystaniu z tej metody znajdziesz w artykule Wskazywanie ceny spersonalizowanej.
  • Usunięto queryPurchases(), która została wcześniej wycofana i zastąpiona przez metodę queryPurchasesAsync wprowadzoną w Bibliotece płatności w Google Play w wersji 4.0.0.
  • Interfejs launchPriceChangeFlow został wycofany i zostanie usunięty w przyszłej wersji. Więcej informacji o alternatywnych rozwiązaniach znajdziesz w artykule Uruchamianie procesu potwierdzania zmiany ceny.
  • Usunięto setVrPurchaseFlow(), które było wcześniej używane podczas tworzenia instancji procesu zakupu. W poprzednich wersjach ta metoda przekierowywała użytkownika, aby dokończył zakup na urządzeniu z Androidem. Po usunięciu tej metody użytkownicy będą mogli dokonywać zakupu w standardowy sposób.

Wprowadzenie Biblioteki płatności w Google Play w wersji 4.1 (23.02.2022)

Wersja 4.1.0 Biblioteki płatności w Google Play i rozszerzenia Kotlin są już dostępne.

Ta wersja zawiera następujące zmiany:

Podsumowanie zmian

Wprowadzenie biblioteki płatności w Google Play w wersji 4.0 (18.05.2021)

Wersja 4.0.0 Biblioteki płatności w Google Play i rozszerzenia Kotlin są już dostępne.

Podsumowanie zmian

Wersja 3.0.3 biblioteki Płatności w Google Play (12.03.2021)

Dostępne są już wersje 3.0.3 Biblioteki płatności w Google Play, rozszerzenia Kotlin i wtyczki Unity.

Poprawki błędów w językach Java i Kotlin

  • Naprawiono wyciek pamięci podczas wywoływania funkcji endConnection().
  • Rozwiązanie problemu z Biblioteką płatności w Google Play w aplikacjach, które używają trybu uruchamiania pojedynczego zadania. A onPurchasesUpdated() wywołanie zwrotne zostanie wywołane, gdy aplikacja zostanie wznowiona z launchera Androida, a okno płatności było widoczne przed zawieszeniem.

Poprawki błędów w Unity

  • Zaktualizuj aplikację do wersji 3.0.3 języka Java, aby naprawić wyciek pamięci i rozwiązać problem uniemożliwiający dokonywanie zakupów po wznowieniu aplikacji z launchera Androida, gdy przed zawieszeniem aplikacji było widoczne okno płatności.

Wersja 3.0.2 Biblioteki płatności w Google Play (24.11.2020)

Wersja 3.0.2 Biblioteki płatności w Google Play i rozszerzenie Kotlin są już dostępne.

Poprawki błędów

  • Naprawiliśmy błąd w rozszerzeniu Kotlin, który powodował, że korutyna kończyła się niepowodzeniem z błędem „Already resumed”.
  • Rozwiązaliśmy problem z nierozwiązanymi odwołaniami, który występował, gdy rozszerzenie Kotlin było używane z biblioteką kotlinx.coroutines w wersji 1.4 lub nowszej.

Wersja 3.0.1 Biblioteki płatności w Google Play (30.09.2020)

Wersja 3.0.1 Biblioteki płatności w Google Play i rozszerzenie Kotlin są już dostępne.

Poprawki błędów

  • Naprawiliśmy błąd polegający na tym, że jeśli aplikacja została zamknięta i przywrócona podczas procesu płatności, funkcja PurchasesUpdatedListener mogła nie zostać wywołana z wynikiem zakupu.

Wersja 3.0 Biblioteki płatności w Google Play (2020-06-08)

Dostępne są już wersja 3.0.0 Biblioteki płatności w Google Play, rozszerzenie Kotlin i wtyczka Unity.

Podsumowanie zmian

  • Usunięto obsługę kodów SKU z nagrodami.
  • Usunięto parametry ChildDirectedUnderAgeOfConsent.
  • Usunięto wycofane metody ładunku dla deweloperów.
  • Usunięto wycofane metody BillingFlowParams.setAccountId()BillingFlowParams.setDeveloperId().
  • Usunięto wycofane metody BillingFlowParams.setOldSkus(String oldSku)BillingFlowParams.addOldSku(String oldSku).
  • Dodano adnotacje dotyczące możliwości przyjmowania wartości null.

Poprawki błędów

  • SkuDetails.getIntroductoryPriceCycles() zwraca teraz int zamiast String.
  • Naprawiliśmy błąd, który powodował, że proces płatności był traktowany jako zawierający dodatkowe parametry, nawet jeśli nie były one ustawione.

Wersja biblioteki Płatności w Google Play 2.2.1 (2020-05-20)

Dostępna jest już wersja 2.2.1 Biblioteki płatności w Google Play.

Poprawki błędów

  • Zaktualizowano domyślną wersję biblioteki płatności w Google Play w języku Java, od której zależy rozszerzenie Kotlin.

Wydanie Biblioteki płatności w Google Play w wersji 2.2.0 i obsługa Unity (23.03.2020)

Wersja 2.2.0 usługi rozliczeniowej Google Play udostępnia funkcje, które pomagają deweloperom przypisywać zakupy do właściwych użytkowników. Te zmiany zastępują konieczność tworzenia rozwiązań niestandardowych na podstawie danych przekazywanych przez dewelopera. W ramach tej aktualizacji funkcja ładunku dewelopera została wycofana i zostanie usunięta w przyszłej wersji. Więcej informacji, w tym zalecane alternatywy, znajdziesz w artykule Ładunek dla programisty.

Biblioteka płatności w Google Play w wersji 2 dla Unity

Oprócz obecnych wersji Biblioteki płatności w Google Play 2 w językach Java i Kotlin udostępniliśmy wersję tej biblioteki do użytku z silnikiem Unity. Deweloperzy gier korzystający z interfejsu Unity do obsługi zakupów w aplikacji mogą już teraz przejść na nową wersję, aby korzystać ze wszystkich funkcji Biblioteki płatności w Google Play 2 i ułatwić sobie późniejsze aktualizacje do przyszłych wersji tej biblioteki.

Więcej informacji znajdziesz w artykule Korzystanie z Płatności w Google Play w Unity.

Podsumowanie zmian

Wersja 2.1.0 Biblioteki płatności w Google Play i wersja 2.1.0 rozszerzenia Kotlin (10 grudnia 2019 r.)

Dostępna jest już wersja 2.1.0 Biblioteki płatności w Google Play oraz nowe rozszerzenie Kotlin. Rozszerzenie Kotlin biblioteki Rozliczeń Play udostępnia alternatywne interfejsy API w języku Kotlin, które zapewniają lepsze bezpieczeństwo w przypadku wartości null i obsługę współprogramów. Przykłady kodu znajdziesz w artykule Korzystanie z Biblioteki płatności w Google Play.

Ta wersja zawiera następujące zmiany:

Podsumowanie zmian

  • BillingFlowParams wycofano setOldSku(String oldSku) i zastąpiono go elementem setOldSku(String oldSku, String purchaseToken), aby rozróżniać sytuacje, w których wiele kont na urządzeniu ma ten sam kod SKU.

Wersja 2.0.3 biblioteki Płatności w Google Play (2019-08-05)

Dostępna jest już wersja 2.0.3 Biblioteki płatności w Google Play.

Poprawki błędów

  • Naprawiliśmy błąd, który powodował, że funkcja querySkuDetailsAsync() czasami kończyła się niepowodzeniem i zwracała kod DEVELOPER_ERROR zamiast wyniku.

Wersja 2.0.2 Biblioteki płatności w Google Play (2019-07-08)

Dostępna jest już wersja 2.0.2 Biblioteki płatności w Google Play. Ta wersja zawiera aktualizacje dokumentacji referencyjnej i nie zmienia funkcjonalności biblioteki.

Wersja 2.0.1 Biblioteki płatności w Google Play (2019-06-06)

Dostępna jest już wersja 2.0.1 Biblioteki płatności w Google Play. Ta wersja zawiera następujące zmiany:

Poprawki błędów

  • Usunęliśmy błąd, który w niektórych przypadkach powodował zwracanie komunikatów debugowania jako null.
  • Rozwiązaliśmy potencjalny problem z wyciekiem pamięci.

Wprowadzenie Biblioteki płatności w Google Play 2.0 (2019-05-07)

Dostępna jest już wersja 2.0 Biblioteki płatności w Google Play. Ta wersja zawiera następujące zmiany:

Zakupy muszą zostać potwierdzone w ciągu 3 dni.

Google Play obsługuje kupowanie produktów w aplikacji i poza nią. Aby zapewnić spójne wrażenia z zakupów w Google Play niezależnie od tego, gdzie użytkownik kupuje Twój produkt, musisz potwierdzać wszystkie zakupy otrzymane za pomocą Biblioteki płatności w Google Play tak szybko, jak to możliwe po przyznaniu użytkownikowi uprawnień. Jeśli nie potwierdzisz zakupu w ciągu 3 dni, użytkownik automatycznie otrzyma zwrot środków, a Google Play unieważni zakup. W przypadku transakcji oczekujących (nowość w wersji 2.0) 3-dniowe okno rozpoczyna się, gdy zakup przejdzie w stan PURCHASED, i nie ma zastosowania, gdy zakup jest w stanie PENDING.

W przypadku subskrypcji musisz potwierdzić każdy zakup, który ma nowy token zakupu. Oznacza to, że musisz potwierdzić wszystkie początkowe zakupy, zmiany abonamentu i ponowne rejestracje, ale nie musisz potwierdzać kolejnych odnowień. Aby sprawdzić, czy zakup wymaga potwierdzenia, możesz sprawdzić pole acknowledgement w zakupie.

Obiekt Purchase zawiera teraz metodę isAcknowledged(), która wskazuje, czy zakup został potwierdzony. Dodatkowo interfejs Google Play Developer API zawiera wartości logiczne potwierdzenia dla obu tych elementów:Purchases.productsPurchases.subscriptions. Zanim potwierdzisz zakup, sprawdź, czy nie został on już potwierdzony.

Zakup możesz potwierdzić za pomocą jednej z tych metod:

  • W przypadku produktów konsumpcyjnych użyj wartości consumeAsync(), która znajduje się w interfejsie API klienta.
  • W przypadku produktów, które nie są konsumowane, użyj parametru acknowledgePurchase() dostępnego w interfejsie API klienta.
  • W interfejsie Server API dostępna jest też nowa metoda acknowledge().

Metoda BillingFlowParams.setSku() została usunięta

W tej wersji usunęliśmy wycofaną wcześniej metodę BillingFlowParams#setSku(). Zanim wyrenderujesz produkty w procesie zakupu, musisz wywołać funkcję BillingClient.querySkuDetailsAsync(), przekazując wynikowy obiekt SkuDetails do funkcji BillingFlowParams.Builder.setSkuDetails().

Przykłady kodu znajdziesz w artykule Korzystanie z Biblioteki płatności w Google Play.

Ładunek dewelopera jest obsługiwany

Wersja 2.0 Biblioteki płatności Google Play dodaje obsługę danych dewelopera – dowolnych ciągów znaków, które można dołączyć do zakupów. Możesz dołączyć parametr z danymi dewelopera do zakupu, ale tylko wtedy, gdy zakup zostanie potwierdzony lub wykorzystany. Różni się to od danych dodatkowych dla programisty w AIDL, gdzie dane dodatkowe można było określić podczas uruchamiania procesu zakupu. Ponieważ zakupy mogą być teraz inicjowane spoza aplikacji, ta zmiana zapewnia, że zawsze będziesz mieć możliwość dodania do nich ładunku.

Aby uzyskać dostęp do ładunku w nowej bibliotece, obiekty Purchase zawierają teraz metodę getDeveloperPayload().

Spójne oferty

Gdy oferujesz kod SKU z rabatem, Google Play zwraca teraz pierwotną cenę kodu SKU, aby użytkownicy widzieli, że otrzymują rabat.

SkuDetails zawiera 2 nowe metody pobierania pierwotnej ceny kodu SKU:

Transakcje oczekujące

W wersji 2.0 Biblioteki płatności w Google Play musisz obsługiwać zakupy, w przypadku których przed przyznaniem uprawnień wymagane jest wykonanie dodatkowej czynności. Użytkownik może na przykład kupić produkt w aplikacji w sklepie stacjonarnym, płacąc gotówką. Oznacza to, że transakcja jest realizowana poza aplikacją. W takim przypadku należy przyznać uprawnienia dopiero po zakończeniu transakcji przez użytkownika.

Aby włączyć oczekujące zakupy, wywołaj enablePendingPurchases() w ramach inicjowania aplikacji.

Użyj Purchase.getPurchaseState() aby określić, czy stan zakupu to PURCHASED czy PENDING. Pamiętaj, że uprawnienia należy przyznawać tylko wtedy, gdy stan to PURCHASED. Aby sprawdzić Purchase stan aktualizacji, wykonaj te czynności:

  1. Podczas uruchamiania aplikacji wywołaj funkcję BillingClient.queryPurchases(), aby pobrać listę nieużytych produktów powiązanych z użytkownikiem.
  2. Wywołaj Purchase.getPurchaseState() na każdym zwróconym obiekcie Purchase.
  3. Zaimplementuj metodę onPurchasesUpdated(), aby reagować na zmiany w obiektach Purchase.

Interfejs Google Play Developer API zawiera też stan PENDING dla Purchases.products. Transakcje oczekujące nie są obsługiwane w przypadku subskrypcji.

W tej wersji wprowadziliśmy też nowy typ powiadomień dla deweloperów w czasie rzeczywistym:OneTimeProductNotification Ten typ powiadomienia zawiera pojedynczą wiadomość, której wartość to ONE_TIME_PRODUCT_PURCHASED lub ONE_TIME_PRODUCT_CANCELED. Ten typ powiadomienia jest wysyłany tylko w przypadku zakupów powiązanych z opóźnionymi formami płatności, takimi jak gotówka.

Potwierdzając zakupy oczekujące, rób to tylko wtedy, gdy stan zakupu to PURCHASED, a nie PENDING.

Zmiany w interfejsie API

Biblioteka płatności w Google Play w wersji 2.0 zawiera kilka zmian w API, które mają na celu obsługę nowych funkcji i wyjaśnienie istniejących.

consumeAsync

consumeAsync() przyjmuje teraz obiekt ConsumeParams zamiast purchaseToken. ConsumeParams zawiera purchaseToken oraz opcjonalny ładunek dewelopera.

W tej wersji usunęliśmy poprzednią wersję consumeAsync().

queryPurchaseHistoryAsync

Aby uniknąć nieporozumień, funkcja queryPurchaseHistoryAsync() zwraca teraz obiekt PurchaseHistoryRecord zamiast obiektu Purchase. Obiekt PurchaseHistoryRecord jest taki sam jak obiekt Purchase, z tym wyjątkiem, że odzwierciedla tylko wartości zwracane przez queryPurchaseHistoryAsync() i nie zawiera pól autoRenewing, orderId ani packageName. Pamiętaj, że zwrócone dane się nie zmieniły – funkcja queryPurchaseHistoryAsync() zwraca te same dane co wcześniej.

Wartości zwracane BillingResult

Interfejsy API, które wcześniej zwracały wartość całkowitą BillingResponse, teraz zwracają obiekt BillingResult. BillingResult zawiera liczbę całkowitą BillingResponse oraz ciąg znaków debugowania, którego możesz użyć do diagnozowania błędów. Ciąg debugowania jest w języku angielskim (Stany Zjednoczone) i nie jest przeznaczony do wyświetlania użytkownikom.

Poprawki błędów

Wersja 1.2.2 Biblioteki płatności w Google Play (2019-03-07)

Dostępna jest już wersja 1.2.2 Biblioteki płatności w Google Play. Ta wersja zawiera następujące zmiany:

Poprawki błędów

  • Rozwiązaliśmy problem z wątkami, który pojawił się w wersji 1.2.1. Wywołania w tle nie blokują już wątku głównego.

Inne zmiany

  • Chociaż nadal zalecamy korzystanie z głównego wątku, możesz teraz tworzyć instancje Biblioteki Płatności w Google Play z wątku w tle.
  • Tworzenie instancji zostało w pełni przeniesione do wątku w tle, aby zmniejszyć ryzyko wystąpienia błędów ANR.

Wersja 1.2.1 Biblioteki płatności w Play (2019-03-04)

Dostępna jest już wersja 1.2.1 Biblioteki płatności w Google Play. Ta wersja zawiera następujące zmiany:

Najważniejsze zmiany

Inne zmiany

  • Dodano publiczne konstruktory dla klas PurchasesResultSkuDetailsResult, aby ułatwić testowanie.
  • Obiekty SkuDetails mogą używać nowej metody getOriginalJson().
  • Wszystkie wywołania usług AIDL są teraz obsługiwane przez wątki w tle.

Poprawki błędów

  • Do publicznych interfejsów API nie są już przekazywane odbiorniki wywołania zwrotnego o wartości null.

Wersja 1.2 Biblioteki płatności w Google Play (2018-10-18)

Dostępna jest już wersja 1.2 Biblioteki płatności w Google Play. Ta wersja zawiera następujące zmiany:

Podsumowanie zmian

  • Biblioteka płatności w Google Play jest teraz licencjonowana na podstawie Umowy licencyjnej dotyczącej pakietu Android SDK.
  • Dodaliśmy interfejs API launchPriceChangeConfirmationFlow, który wyświetla użytkownikom prośbę o sprawdzenie oczekującej zmiany ceny subskrypcji.
  • Dodano obsługę nowego trybu proporcjonalnego rozliczania DEFERRED podczas uaktualniania lub obniżania wersji subskrypcji użytkownika.
  • W klasie BillingFlowParams zastąpiliśmy setSku() wartością setSkuDetails().
  • Drobne poprawki błędów i optymalizacje kodu.

Potwierdzenie zmiany ceny

Możesz teraz zmienić cenę subskrypcji w Konsoli Google Play i poprosić użytkowników o sprawdzenie i zaakceptowanie nowej ceny po wejściu do aplikacji.

Aby użyć tego interfejsu API, utwórz obiekt PriceChangeFlowParams, używając skuDetails produktu subskrypcji, a następnie wywołaj launchPriceChangeConfirmationFlow(). Zaimplementuj funkcję PriceChangeConfirmationListener, która będzie obsługiwać wynik po zakończeniu procesu potwierdzania zmiany ceny , jak pokazano w tym fragmencie kodu:

Kotlin

val priceChangeFlowParams = PriceChangeFlowParams.newBuilder()
    .setSkuDetails(skuDetailsOfThePriceChangedSubscription)
    .build()

billingClient.launchPriceChangeConfirmationFlow(activity,
        priceChangeFlowParams,
        object : PriceChangeConfirmationListener() {
            override fun onPriceChangeConfirmationResult(responseCode: Int) {
                // Handle the result.
            }
        })

Java

PriceChangeFlowParams priceChangeFlowParams =
        PriceChangeFlowParams.newBuilder()
    .setSkuDetails(skuDetailsOfThePriceChangedSubscription)
    .build();

billingClient.launchPriceChangeConfirmationFlow(activity,
        priceChangeFlowParams,
        new PriceChangeConfirmationListener() {
            @Override
            public void onPriceChangeConfirmationResult(int responseCode) {
                // Handle the result.
            }
        });

Proces potwierdzania zmiany ceny wyświetla okno dialogowe z informacjami o nowej cenie, w którym użytkownicy są proszeni o jej zaakceptowanie. Ten przepływ zwraca kod odpowiedzi typu BillingClient.BillingResponse.

Nowy tryb proporcjonalnego rozliczania

Podczas przechodzenia na wyższą lub niższą wersję subskrypcji użytkownika możesz użyć nowego trybu proporcjonalnego rozliczenia, DEFERRED. W tym trybie subskrypcja użytkownika zostanie zaktualizowana przy kolejnym odnowieniu. Więcej informacji o tym, jak ustawić ten tryb proporcjonalnego podziału, znajdziesz w artykule Ustawianie trybu proporcjonalnego podziału.

Nowa metoda ustawiania szczegółów kodu SKU

W klasie BillingFlowParams metoda setSku() została wycofana. Ta zmiana ma na celu optymalizację procesu Płatności w Google Play.

Podczas tworzenia nowej instancji BillingFlowParams w kliencie płatności w aplikacji zalecamy bezpośrednie używanie obiektu JSON za pomocą setSkuDetails(), jak pokazano w tym fragmencie kodu:

W klasie BillingFlowParams Builder metoda setSku() została wycofana. Zamiast tego użyj metody setSkuDetails(), jak pokazano w tym fragmencie kodu: Obiekt przekazany do obiektu setSkuDetails() pochodzi z metody querySkuDetailsAsync().

Kotlin

private lateinit var mBillingClient: BillingClient
private val mSkuDetailsMap = HashMap<String, SkuDetails>()

private fun querySkuDetails() {
    val skuDetailsParamsBuilder = SkuDetailsParams.newBuilder()
    mBillingClient.querySkuDetailsAsync(skuDetailsParamsBuilder.build()
    ) { responseCode, skuDetailsList ->
        if (responseCode == 0) {
            for (skuDetails in skuDetailsList) {
                mSkuDetailsMap[skuDetails.sku] = skuDetails
            }
        }
    }
}

private fun startPurchase(skuId: String) {
    val billingFlowParams = BillingFlowParams.newBuilder()
    .setSkuDetails(mSkuDetailsMap[skuId])
    .build()
}

Java

private BillingClient mBillingClient;
private Map<String, SkuDetails> mSkuDetailsMap = new HashMap<>();

private void querySkuDetails() {
    SkuDetailsParams.Builder skuDetailsParamsBuilder
            = SkuDetailsParams.newBuilder();
    mBillingClient.querySkuDetailsAsync(skuDetailsParamsBuilder.build(),
            new SkuDetailsResponseListener() {
                @Override
                public void onSkuDetailsResponse(int responseCode,
                        List<SkuDetails> skuDetailsList) {
                    if (responseCode == 0) {
                        for (SkuDetails skuDetails : skuDetailsList) {
                            mSkuDetailsMap.put(skuDetails.getSku(), skuDetails);
                        }
                    }
                }
            });
}

private void startPurchase(String skuId) {
    BillingFlowParams billingFlowParams = BillingFlowParams.newBuilder()
            .setSkuDetails(mSkuDetailsMap.get(skuId))
            .build();
}

Wersja 1.1 Biblioteki płatności w Play (2018-05-07)

Dostępna jest już wersja 1.1 Biblioteki płatności w Google Play. Ta wersja zawiera następujące zmiany:

Podsumowanie zmian

  • Dodaliśmy obsługę określania trybu proporcjonalnego rozliczenia w metodzie BillingFlowParams podczas przechodzenia na wyższą lub niższą wersję istniejącej subskrypcji.
  • Flaga logiczna replaceSkusProrationBillingFlowParams nie jest już obsługiwana. Zamiast niej użyj zasady replaceSkusProrationMode.
  • launchBillingFlow() wywołuje teraz wywołanie zwrotne w przypadku nieudanych odpowiedzi.

Zmiany w działaniu

Wersja 1.1 Biblioteki płatności w Google Play zawiera te zmiany w działaniu:

Deweloperzy mogą ustawić replaceSkusProrationMode w klasie BillingFlowParams.

ProrationMode zawiera więcej informacji o rodzaju proporcjonalnego rozliczenia w przypadku przejścia na wyższą lub niższą wersję subskrypcji użytkownika.

Kotlin

BillingFlowParams.newBuilder()
    .setSku(skuId)
    .setType(billingType)
    .setOldSku(oldSku)
    .setReplaceSkusProrationMode(replaceSkusProrationMode)
    .build()

Java

BillingFlowParams.newBuilder()
    .setSku(skuId)
    .setType(billingType)
    .setOldSku(oldSku)
    .setReplaceSkusProrationMode(replaceSkusProrationMode)
    .build();

Google Play obsługuje te tryby proporcjonalnego rozliczania:

IMMEDIATE_WITH_TIME_PRORATION Wymiana zaczyna obowiązywać natychmiast, a nowy czas wygaśnięcia zostanie proporcjonalnie rozliczony i zwrócony lub obciążony na koncie użytkownika. Jest to obecnie domyślne działanie.
IMMEDIATE_AND_CHARGE_PRORATED_PRICE Wymiana zaczyna obowiązywać natychmiast, a cykl rozliczeniowy pozostaje bez zmian. Zostanie pobrana cena za pozostały okres.

Uwaga: ta opcja jest dostępna tylko w przypadku uaktualnienia subskrypcji.

IMMEDIATE_WITHOUT_PRORATION Wymiana następuje natychmiast, a nowa cena zostanie naliczona przy następnym odnowieniu. Cykl rozliczeniowy pozostaje bez zmian.

replaceSkusProration nie jest już obsługiwana w przypadku klasy BillingFlowParams.

Deweloperzy mogli ustawić flagę logiczną, aby pobierać proporcjonalną kwotę za prośbę o przejście na wyższą wersję subskrypcji. Obsługujemy już parametr ProrationMode, który zawiera bardziej szczegółowe instrukcje dotyczące proporcjonalnego rozliczania, więc ta wartość logiczna nie jest już obsługiwana.

launchBillingFlow() wywołuje teraz wywołanie zwrotne w przypadku nieudanych odpowiedzi

Biblioteka płatności zawsze wywołuje zwrotne wywołanie PurhcasesUpdatedListener i asynchronicznie zwraca BillingResponse. Zachowana jest też synchroniczna wartość zwracana BillingResponse.

Poprawki błędów

  • Prawidłowo kończy działanie w metodach asynchronicznych, gdy usługa jest odłączona.
  • Builder Obiekty parametrów nie zmieniają już wbudowanych obiektów.
  • Problem 68087141: launchBillingFlow() teraz wywołuje wywołanie zwrotne w przypadku nieudanych odpowiedzi.

Wydanie Biblioteki płatności w Google Play w wersji 1.0 (19 września 2017 r., komunikat)

Dostępna jest już wersja 1.0 Biblioteki płatności w Google Play. Ta wersja zawiera następujące zmiany:

Ważne zmiany

  • Uprawnienie do płatności wbudowanych w pliku manifestu biblioteki. Nie musisz już dodawać uprawnienia com.android.vending.BILLING do pliku manifestu Androida.
  • Nowy konstruktor dodany do klasy BillingClient.Builder.
  • Wprowadzono wzorzec konstruktora dla klasy SkuDetailsParams, która będzie używana w metodach do wysyłania zapytań o kody SKU.
  • Zaktualizowaliśmy kilka metod interfejsu API, aby zapewnić spójność (te same nazwy i kolejność argumentów zwracanych).

Zmiany w działaniu

Wersja 1.0 Biblioteki płatności w Google Play zawiera te zmiany w działaniu:

Klasa BillingClient.Builder

BillingClient.Builder jest teraz inicjowany za pomocą nowego wzorca konstruktora:

Kotlin

billingClient = BillingClient.newBuilder(context).setListener(this).build()

Java

billingClient = BillingClient.newBuilder(context).setListener(this).build();

Metoda launchBillingFlow jest teraz wywoływana za pomocą klasy BillingFlowParams

Aby zainicjować proces płatności za zakup lub subskrypcję, metoda launchBillingFlow() otrzymuje instancję BillingFlowParams zainicjowaną za pomocą parametrów specyficznych dla żądania:

Kotlin

BillingFlowParams.newBuilder().setSku(skuId)
        .setType(billingType)
        .setOldSku(oldSku)
        .build()

// Then, use the BillingFlowParams to start the purchase flow
val responseCode = billingClient.launchBillingFlow(builder.build())

Java

BillingFlowParams.newBuilder().setSku(skuId)
                              .setType(billingType)
                              .setOldSku(oldSku)
                              .build();

// Then, use the BillingFlowParams to start the purchase flow
int responseCode = billingClient.launchBillingFlow(builder.build());

Nowy sposób wysyłania zapytań o dostępne produkty

Argumenty metod queryPurchaseHistoryAsync()querySkuDetailsAsync() zostały opakowane w wzorzec Builder:

Kotlin

val params = SkuDetailsParams.newBuilder()
params.setSkusList(skuList)
        .setType(itemType)
billingClient.querySkuDetailsAsync(params.build(), object : SkuDetailsResponseListener() {
    ...
})

Java

SkuDetailsParams.Builder params = SkuDetailsParams.newBuilder();
params.setSkusList(skuList)
        .setType(itemType);
billingClient.querySkuDetailsAsync(params.build(), new SkuDetailsResponseListener() {...})

Wynik jest teraz zwracany za pomocą kodu wyniku i listy obiektów SkuDetails zamiast poprzedniej klasy opakowującej, co ułatwia korzystanie z interfejsu API i zapewnia spójność:

Kotlin

fun onSkuDetailsResponse(@BillingResponse responseCode: Int, skuDetailsList: List<SkuDetails>)

Java

public void onSkuDetailsResponse(@BillingResponse int responseCode, List<SkuDetails> skuDetailsList)

Zmieniono kolejność parametrów w metodzie onConsumeResponse()

Kolejność argumentów funkcji onConsumeResponse w interfejsie ConsumeResponseListener została zmieniona, aby była spójna w całym interfejsie API:

Kotlin

fun onConsumeResponse(@BillingResponse responseCode: Int, outToken: String)

Java

public void onConsumeResponse(@BillingResponse int responseCode, String outToken)

Rozpakowany obiekt PurchaseResult

PurchaseResult został rozpakowany, aby zachować spójność w naszym interfejsie API:

Kotlin

fun onPurchaseHistoryResponse(@BillingResponse responseCode: Int, purchasesList: List<Purchase>)

Java

void onPurchaseHistoryResponse(@BillingResponse int responseCode, List<Purchase> purchasesList)

Poprawki błędów

Wersja przedpremierowa 1 (12 czerwca 2017 r., komunikat)

Uruchomiliśmy wersję przedpremierową dla programistów, która ma uprościć proces tworzenia aplikacji pod względem rozliczeń, dzięki czemu deweloperzy mogą skupić się na implementowaniu logiki specyficznej dla aplikacji na Androida, takiej jak architektura aplikacji i struktura nawigacji.

Biblioteka zawiera kilka wygodnych klas i funkcji, których możesz używać podczas integrowania aplikacji na Androida z interfejsem Google Play Billing API. Biblioteka zapewnia też warstwę abstrakcji nad usługą Android Interface Definition Language (AIDL), co ułatwia deweloperom definiowanie interfejsu między aplikacją a interfejsem Google Play Billing API.