ย้ายข้อมูลจากเวอร์ชัน 6 หรือ 7 ไปยัง Google Play Billing Library 8

เอกสารนี้อธิบายวิธีย้ายข้อมูลจาก Google Play Billing Library (PBL) 6 หรือ 7 ไปยัง PBL 8 และวิธีผสานรวมกับความสามารถในการสมัครใช้บริการแบบใหม่ที่ไม่บังคับ

หากต้องการดูรายการการเปลี่ยนแปลงทั้งหมดในเวอร์ชัน 8.0.0 โปรดอ่านบันทึกประจำรุ่น

ภาพรวม

PBL 8 มีการปรับปรุง API ที่มีอยู่พร้อมกับการนำ API ที่เลิกใช้งานไปก่อนหน้านี้ออก นอกจากนี้ ไลบรารีเวอร์ชันนี้ยังมี API ใหม่ สำหรับผลิตภัณฑ์แบบครั้งเดียวด้วย

ความเข้ากันได้แบบย้อนหลังสำหรับการอัปเกรด PBL

หากต้องการย้ายข้อมูลไปยัง PBL 8 คุณต้องอัปเดตหรือนำการอ้างอิง API ที่มีอยู่บางรายการออกจากแอปตามที่อธิบายไว้ในหมายเหตุประจำรุ่นและในภายหลัง ในคู่มือการย้ายข้อมูลนี้

อัปเกรดจาก PBL 6 หรือ 7 เป็น PBL 8

หากต้องการอัปเกรดจาก PBL 6 หรือ 7 เป็น PBL 8 ให้ทำตามขั้นตอนต่อไปนี้

  1. อัปเดตเวอร์ชันทรัพยากร Dependency ของ Play Billing Library ในไฟล์ build.gradle ของแอป

    dependencies {
      def billingVersion = 8.0.0
      implementation "com.android.billingclient:billing:$billingVersion"
    }
    
  2. (ใช้ได้กับการอัปเกรดจาก PBL 6 เป็น PBL 8 เท่านั้น) จัดการการเปลี่ยนแปลง API ที่เกี่ยวข้องกับการสมัครใช้บริการในแอป

    ตารางต่อไปนี้แสดงรายการ API ที่เกี่ยวข้องกับการสมัครใช้บริการซึ่งจะถูกนำออกใน PBL 8 และ API ทางเลือกที่เกี่ยวข้องซึ่งคุณต้องใช้ในแอป

    นำ API ที่เลิกใช้งานไปก่อนหน้านี้ออกใน PBL 8 API สำรองที่จะใช้
    setOldSkuPurchaseToken setOldPurchaseToken
    setReplaceProrationMode setSubscriptionReplacementMode
    setReplaceSkusProrationMode setSubscriptionReplacementMode
  3. อัปเดตการติดตั้งใช้งานเมธอด queryProductDetailsAsync

    มีการเปลี่ยนแปลงลายเซ็นของเมธอด ProductDetailsResponseListener.onProductDetailsResponse ซึ่ง ต้องมีการเปลี่ยนแปลงในแอปสำหรับการติดตั้งใช้งาน queryProductDetailsAsync ดูข้อมูลเพิ่มเติมได้ที่แสดงผลิตภัณฑ์ที่พร้อมจำหน่าย

  4. จัดการ API ที่ถูกนำออก

    อัปเกรด จาก

    PBL 8 ไม่รองรับ API ที่แสดงในตารางต่อไปนี้อีกต่อไป หากการใช้งานของคุณใช้ API ที่ถูกนำออกไปเหล่านี้ โปรดดูตารางเพื่อหา API ทางเลือกที่เกี่ยวข้อง

    นำ API ที่เลิกใช้งานไปก่อนหน้านี้ออกใน PBL 8 API สำรองที่จะใช้
    queryPurchaseHistoryAsync API ดูประวัติการซื้อของคำค้นหา
    querySkuDetailsAsync queryProductDetailsAsync
    enablePendingPurchases() (API ที่ไม่มีพารามิเตอร์) enablePendingPurchases(PendingPurchaseParams params)
    โปรดทราบว่าฟังก์ชันการทำงานของ enablePendingPurchases() ที่เลิกใช้งานแล้วเทียบเท่ากับ enablePendingPurchases(PendingPurchasesParams.newBuilder().enableOneTimeProducts().build())
    queryPurchasesAsync(String skuType, PurchasesResponseListener listener) queryPurchasesAsync
    BillingClient.Builder.enableAlternativeBilling BillingClient.Builder.enableUserChoiceBilling
    AlternativeBillingListener UserChoiceBillingListener
    AlternativeChoiceDetails UserChoiceDetails

    อัปเกรด จาก

    ตารางต่อไปนี้แสดงรายการ API ที่จะนำออกใน PBL 8 และ API ทางเลือกที่เกี่ยวข้องซึ่งคุณต้องใช้ในแอป

    นำ API ที่เลิกใช้งานไปก่อนหน้านี้ออกใน PBL 8 API สำรองที่จะใช้
    queryPurchaseHistoryAsync API ดูประวัติการซื้อของคำค้นหา
    querySkuDetailsAsync queryProductDetailsAsync
    enablePendingPurchases() (API ที่ไม่มีพารามิเตอร์) enablePendingPurchases(PendingPurchaseParams params)
    โปรดทราบว่าฟังก์ชันการทำงานของ enablePendingPurchases() ที่เลิกใช้งานแล้วเทียบเท่ากับ enablePendingPurchases(PendingPurchasesParams.newBuilder().enableOneTimeProducts().build())
    queryPurchasesAsync(String skuType, PurchasesResponseListener listener) queryPurchasesAsync

  5. (แนะนำ) เปิดใช้การเชื่อมต่อบริการอีกครั้งโดยอัตโนมัติ

    Play Billing Library สามารถพยายามสร้างการเชื่อมต่อบริการใหม่โดยอัตโนมัติ หากมีการเรียก API ขณะที่บริการ ถูกตัดการเชื่อมต่อ ดูข้อมูลเพิ่มเติมได้ที่หัวข้อเปิดใช้การเชื่อมต่อบริการอีกครั้งโดยอัตโนมัติ

  6. การเปลี่ยนแปลงที่ไม่บังคับ