การซื้อการสมัครใช้บริการอาจมีสถานะต่างๆ ตลอดวงจรการใช้งาน โดยขึ้นอยู่กับหลายปัจจัย ซึ่งรวมถึงลักษณะการต่ออายุอัตโนมัติ สถานการณ์การชำระเงินถูกปฏิเสธ และการดำเนินการจัดการของนักพัฒนาแอป
จัดการวงจรการใช้งานสำหรับการสมัครใช้บริการแบบต่ออายุอัตโนมัติ
เมื่อสถานะการสมัครใช้บริการของผู้ใช้เปลี่ยนแปลง เซิร์ฟเวอร์แบ็กเอนด์จะได้รับข้อความ SubscriptionNotification
หากต้องการอัปเดตสถานะในแบ็กเอนด์ ให้เรียกใช้ API
purchases.subscriptionsv2.get
โดยมีโทเค็นการซื้อรวมอยู่ในการแจ้งเตือน ปลายทางนี้จะแสดงสถานะการสมัครใช้บริการล่าสุดเมื่อระบุโทเค็นการซื้อ และถือเป็น
แหล่งที่มาของความจริงสำหรับการจัดการการสมัครใช้บริการ
โทเค็นการซื้อจะใช้ได้ตั้งแต่การลงชื่อสมัครใช้จนถึง 60 วันหลังจากการ หมดอายุ หลังจากวันที่ดังกล่าว โทเค็นการซื้อจะใช้เรียก Google Play Developer API ไม่ได้อีกต่อไป
วิธีการอื่นๆ ในpurchases.subscriptions
ปลายทางยังคงใช้งานได้
การซื้อการสมัครใช้บริการแบบต่ออายุใหม่อัตโนมัติ
เมื่อผู้ใช้ซื้อการสมัครใช้บริการ ระบบจะส่งข้อความ SubscriptionNotification
ที่มี
ประเภท SUBSCRIPTION_PURCHASED
ไปยังไคลเอ็นต์ RTDN ของคุณ ไม่ว่าคุณจะได้รับการแจ้งเตือนนี้หรือลงทะเบียนการซื้อใหม่ในแอปผ่าน
PurchasesUpdatedListener
หรือการดึงข้อมูลการซื้อด้วยตนเองในเมธอด onResume()
ของแอป คุณควรประมวลผลการซื้อใหม่ในแบ็กเอนด์ที่ปลอดภัย โดยคุณต้องทำตามขั้นตอนต่อไปนี้:
- ส่งคำค้นหาไปยังปลายทาง
purchases.subscriptionsv2.get
เพื่อรับทรัพยากร การสมัครใช้บริการที่มีสถานะการสมัครใช้บริการล่าสุด - ตรวจสอบว่าค่าของฟิลด์
subscriptionState
คือSUBSCRIPTION_STATE_ACTIVE
- ยืนยันการซื้อ
- ให้สิทธิ์ผู้ใช้เข้าถึงเนื้อหา ระบบจะระบุบัญชีผู้ใช้ที่เชื่อมโยงกับการซื้อได้ด้วยออบเจ็กต์
ExternalAccountIdentifiers
จากทรัพยากรการสมัครใช้บริการ หากมีการตั้งค่าตัวระบุในเวลาที่ซื้อโดยใช้setObfuscatedAccountId
และsetObfuscatedProfileId
นอกจากนี้ Play Billing Library ยังมีเมธอดสำหรับรับทราบการสมัครใช้บริการ
acknowledgePurchase()
และเมธอดสำหรับตรวจสอบสถานะการรับทราบ
isAcknowledged()
อย่างไรก็ตาม เราขอแนะนำให้คุณจัดการการประมวลผลการซื้อในแบ็กเอนด์เพื่อความปลอดภัยที่ดียิ่งขึ้น
แหล่งข้อมูลการสมัครใช้บริการสำหรับการซื้อใหม่จะมีลักษณะคล้ายกับตัวอย่างต่อไปนี้
{
"kind": "androidpublisher#subscriptionPurchaseV2",
"startTime": "2022-04-22T18:39:58.270Z",
"regionCode": "US",
"subscriptionState": "SUBSCRIPTION_STATE_ACTIVE",
"latestOrderId": "GPA.3333-4137-0319-36762",
"acknowledgementState": "ACKNOWLEDGEMENT_STATE_PENDING", // need to acknowledge new purchases
"lineItems": [
{
"productId": "sub_variant_plan01",
"expiryTime": next_renewal_date,
"autoRenewingPlan": {
"autoRenewEnabled": true
}
}
],
}
การต่ออายุการสมัครรับข้อมูล
สำหรับการสมัครใช้บริการแบบต่ออายุใหม่อัตโนมัติที่ไม่ได้เป็นการผ่อนชำระ ระบบจะส่งSUBSCRIPTION_RENEWED
การแจ้งเตือนเมื่อการสมัครใช้บริการต่ออายุ สำหรับการสมัครใช้บริการแบบผ่อนชำระ ระบบจะส่งการแจ้งเตือนSUBSCRIPTION_RENEWED
ทุกครั้งที่มีการเรียกเก็บเงินสำหรับการสมัครใช้บริการในวันที่เรียกเก็บเงิน ตรวจสอบว่าผู้ใช้ยังมีสิทธิ์ในการสมัครใช้บริการ แล้วอัปเดตสถานะการสมัครใช้บริการด้วย expiryTime
ใหม่ที่ระบุไว้ในแหล่งข้อมูลการสมัครใช้บริการที่ส่งคืนจาก Google Play Developer API แหล่งข้อมูลการติดตามจะมีลักษณะคล้ายกับตัวอย่างต่อไปนี้
{
"kind": "androidpublisher#subscriptionPurchaseV2",
"startTime": "2022-04-22T18:39:58.270Z",
"regionCode": "US",
"subscriptionState": "SUBSCRIPTION_STATE_ACTIVE",
"latestOrderId": "GPA.3333-4137-0319-36762",
"acknowledgementState": "ACKNOWLEDGEMENT_STATE_ACKNOWLEDGED",
"lineItems": [
{
"productId": "sub_variant_plan01",
"expiryTime": next_renewal_date,
"autoRenewingPlan": {
"autoRenewEnabled": true
}
}
]
}
คุณไม่จำเป็นต้องรับทราบการต่ออายุการสมัครใช้บริการ
ระยะเวลาผ่อนผัน
หากพบปัญหาการชำระเงินสำหรับการต่ออายุการสมัครใช้บริการ Google จะแจ้งให้ผู้ใช้ทราบและพยายามต่ออายุการสมัครใช้บริการเป็นระยะๆ สักระยะหนึ่งก่อนที่การสมัครใช้บริการจะหมดอายุ ระยะเวลาการกู้คืนนี้อาจประกอบด้วยระยะเวลาผ่อนผัน ตามด้วยช่วงการระงับบัญชี ในระยะเวลาผ่อนผัน ผู้ใช้ควร ยังคงมีสิทธิ์เข้าถึงสิทธิ์ในการสมัครใช้บริการ
เมธอด
queryPurchasesAsync()
จะยังคงแสดงผลการซื้อที่อยู่ในช่วงผ่อนผัน หากแอปของคุณอาศัย queryPurchasesAsync
เพียงอย่างเดียวเพื่อตรวจสอบว่าผู้ใช้มีสิทธิ์สมัครใช้บริการหรือไม่ แอปควรจัดการระยะเวลาผ่อนผันโดยอัตโนมัติ เนื่องจากระบบจะแสดงการสมัครใช้บริการเหล่านี้ว่าใช้งานอยู่ผ่าน Play Billing Library
การซิงค์สถานะการสมัครใช้บริการกับแบ็กเอนด์จะช่วยให้คุณทราบถึงการชำระเงินที่ถูกปฏิเสธได้มากขึ้น
และให้บริบทเพิ่มเติมขณะที่คุณพยายามลดการเลิกใช้งานโดยไม่ตั้งใจ
รอรับข้อความ
SubscriptionNotification
ที่มีประเภท SUBSCRIPTION_IN_GRACE_PERIOD
เพื่อรับการแจ้งเตือนเมื่อผู้ใช้เข้าสู่
ระยะเวลาผ่อนผัน ขณะที่ผู้ใช้อยู่ในช่วงระยะเวลาผ่อนผัน resource
การสมัครใช้บริการ
จะมี autoRenewEnabled = true
Google Play จะขยายค่า expiryTime
แบบไดนามิกจนกว่าระยะเวลาผ่อนผันจะหมดอายุ เนื่องจากสิทธิ์
ควรมีผลจนกว่าผู้ใช้จะยกเลิกหรือระยะเวลาผ่อนผันจะสิ้นสุดลงตามระยะเวลาสูงสุด
ค่าของฟิลด์ subscriptionState
ในช่วงเวลานี้คือ
SUBSCRIPTION_STATE_IN_GRACE_PERIOD
ทรัพยากรการสมัครใช้บริการจะมีลักษณะคล้ายกับตัวอย่างต่อไปนี้
{
"kind": "androidpublisher#subscriptionPurchaseV2",
...
"subscriptionState": "SUBSCRIPTION_STATE_IN_GRACE_PERIOD",
...
"lineItems": [
{
"productId": "sub_variant_plan01",
"expiryTime": timestamp_in_future,
"autoRenewingPlan": {
"autoRenewEnabled": true
}
}
],
}
Play จะแจ้งให้ผู้ใช้ที่อยู่ในระยะเวลาผ่อนผันทราบว่าการชำระเงินถูกปฏิเสธ และแจ้งให้ผู้ใช้แก้ไขปัญหาเกี่ยวกับวิธีการชำระเงินใน Play Store เมื่อ ผู้ใช้เข้าสู่ระยะเวลาผ่อนผัน คุณควรสนับสนุนให้ผู้ใช้แก้ไข วิธีการชำระเงินในกรณีที่การชำระเงินไม่สำเร็จโดยไม่ได้ตั้งใจ วิธีที่ตรงไปตรงมาในการทำเช่นนี้คือการใช้ API การรับส่งข้อความในแอป หากคุณเรียกใช้ API นี้ เมื่อผู้ใช้เปิดแอปของคุณ ผู้ใช้จะเห็นข้อความของ Play ใน SnackBar ชั่วคราวที่แจ้งให้ผู้ใช้ทราบว่าระบบปฏิเสธการชำระเงิน ข้อความนี้ยังมี Deep Link ให้ผู้ใช้แก้ไขวิธีการชำระเงินใน Google Play ด้วย
ทันทีที่ผู้ใช้แก้ไขวิธีการชำระเงิน การสมัครใช้บริการจะต่ออายุตามวันที่ต่ออายุเดิม และคุณจะจัดการการต่ออายุได้ตามที่อธิบายไว้ในการต่ออายุ
หากผู้ใช้ไม่แก้ไขวิธีการชำระเงินในช่วงระยะเวลาผ่อนผัน การสมัครใช้บริการจะเข้าสู่การระงับบัญชี และผู้ใช้จะเสียสิทธิ์
การเข้าถึงและการกู้คืนในช่วงระยะเวลาผ่อนผัน
รูปที่ 2 แสดงไทม์ไลน์ของการสมัครใช้บริการที่เข้าสู่ระยะเวลาผ่อนผันและ กู้คืนได้เมื่อผู้ใช้แก้ไขวิธีการชำระเงิน หลังจากระยะเวลาผ่อนผันสิ้นสุดลง ผู้ใช้จะเสียสิทธิประโยชน์จากการสมัครใช้บริการและบัญชีจะถูกระงับ

สิ่งสำคัญที่ควรทราบมีดังนี้
- ผู้ใช้ควรยังคงเข้าถึงสิทธิประโยชน์ของการสมัครใช้บริการได้ในระหว่างระยะเวลาผ่อนผัน
- เมื่อการสมัครใช้บริการกลับมาทำงานได้อีกครั้งในช่วงระยะเวลาผ่อนผัน วันที่ต่ออายุจะไม่รีเซ็ต
- หากคุณเพิ่มระยะเวลาผ่อนผัน เช่น จาก 7 วันเป็น 14 วัน ผู้ใช้ที่อยู่ในระยะเวลาผ่อนผันจะได้รับสิทธิ์เข้าถึงสิทธิประโยชน์จากการสมัครใช้บริการนานขึ้น
- หากคุณลดระยะเวลาผ่อนผัน ผู้ใช้ที่อยู่ในระยะเวลาผ่อนผันเก่าจนเกินระยะเวลาผ่อนผันใหม่จะถูกเพิกถอนสิทธิประโยชน์จากการสมัครใช้บริการทันที เช่น หากคุณลดระยะเวลาผ่อนผันจาก 14 วันเป็น 7 วัน ระบบจะเพิกถอนสิทธิประโยชน์จากการสมัครใช้บริการของผู้ใช้ที่อยู่ในช่วงวันที่ 8-14 ของระยะเวลาผ่อนผันเดิมทันที
- การสมัครใช้บริการจะยังคงอยู่ในสถานะใช้งานอยู่ และคุณจะไม่ได้รับ RTDN ระยะผ่อนผัน จนกว่าระยะผ่อนผันแบบเงียบจะสิ้นสุดลง
ระยะเวลาผ่อนผันแบบเงียบ
คุณตั้งค่าระยะเวลาผ่อนผันเป็น 0 วันได้ แต่ Play จะรออย่างน้อย 1 วันเพื่อให้มีเวลาเพียงพอในการลองชำระเงินอีกครั้ง ระยะเวลาผ่อนผันแบบเงียบนี้เป็น
ตาข่ายนิรภัยสำหรับการประมวลผลการชำระเงิน ในระยะเวลา 24 ชั่วโมงนี้ การสมัครใช้บริการจะยังคงอยู่ในสถานะACTIVE
วิธีที่ดีที่สุดในการติดตามการเปลี่ยนแปลงสถานะการสมัครใช้บริการคือการ
รับฟังและตอบสนองต่อการแจ้งเตือนแบบเรียลไทม์สำหรับนักพัฒนาแอป (RTDN) เรียกใช้เมธอด
purchases.subscriptionsv2.get()
ที่เวลา RTDN แทนเวลาหมดอายุเพื่อให้ได้สถานะการสมัครใช้บริการที่แม่นยำยิ่งขึ้น
คุณจะได้รับการแจ้งเตือนอย่างใดอย่างหนึ่งต่อไปนี้ ทั้งนี้ขึ้นอยู่กับสถานะการสมัครใช้บริการหลังจากช่วงผ่อนผันแบบเงียบ 24 ชั่วโมง
SUBSCRIPTION_ON_HOLD
(หากเปิดใช้)SUBSCRIPTION_CANCELED
(หากยกเลิก)SUBSCRIPTION_EXPIRED
(หากหมดอายุ)SUBSCRIPTION_RENEWED
(หากต่ออายุสำเร็จ)
นอกจากนี้ คุณยังเรียกใช้เมธอด subscriptionV2.get()
ได้ทุกเมื่อหลังจากระยะเวลาผ่อนผันแบบเงียบ 24 ชั่วโมงเพื่อดูสถานะล่าสุดของการสมัครใช้บริการ
การระงับบัญชี
หากการต่ออายุการสมัครใช้บริการมีปัญหาเกี่ยวกับการชำระเงิน หลังจากระยะเวลาผ่อนผันสิ้นสุดลง ช่วงการระงับบัญชีจะเริ่มขึ้น เมื่อการสมัครใช้บริการเข้าสู่การระงับบัญชี คุณควรบล็อกการเข้าถึงสิทธิ์ ของการสมัครใช้บริการ
ในระหว่างการระงับบัญชี คุณควรจัดการการยกเลิก การคืนค่า หรือการซื้อการสมัครใช้บริการซ้ำตามความจำเป็น เนื่องจากผู้ใช้อาจทำการเปลี่ยนแปลงเหล่านี้ได้ในขณะที่การสมัครใช้บริการ ถูกระงับ
RTDN จะแจ้งให้คุณทราบเมื่อผู้ใช้เข้าสู่ระยะเวลาการระงับบัญชี เพื่อให้คุณแจ้งให้ผู้ใช้ทราบโดยเร็วที่สุดถึงสาเหตุที่ระบบระงับสิทธิ์เข้าถึงการสมัครใช้บริการ วิธีที่ตรงไปตรงมาในการดำเนินการนี้คือการใช้ In-App Messaging API การเรียก API นี้เมื่อผู้ใช้เปิดแอปจะแสดงข้อความในแถบแสดงข้อความชั่วคราวแก่ผู้ใช้เพื่อแจ้งให้ทราบว่าการชำระเงินถูกปฏิเสธ ข้อความนี้ยังมี Deep Link สำหรับให้ผู้ใช้แก้ไขวิธีการชำระเงินใน Google Play ด้วย
หากผู้ใช้เข้าถึงเนื้อหาการสมัครใช้บริการนอกแอปได้ ผู้ใช้อาจพบว่าตนเองเสียสิทธิ์เข้าถึงในแพลตฟอร์มต่างๆ คุณอาจต้องการ ส่งการแจ้งเตือนแบบพุชหรืออีเมลถึงผู้ใช้เพื่อแจ้งให้ทราบว่า การสมัครใช้บริการของผู้ใช้ไม่ได้ใช้งานอีกต่อไปเนื่องจากการชำระเงินถูกปฏิเสธ
ระบบจะไม่แสดงผลการสมัครใช้บริการด้วยเมธอด
queryPurchasesAsync()
ในระหว่างการระงับบัญชี ดังนั้นหากแอปของคุณใช้เมธอดนี้เพื่อแสดง
การซื้อที่มีอยู่ คุณควรสนับสนุนการระงับบัญชีโดยค่าเริ่มต้น
การแจ้งเตือนแบบเรียลไทม์สำหรับนักพัฒนาแอปจะส่งข้อความ
SubscriptionNotification
ที่มีประเภท SUBSCRIPTION_ON_HOLD
เมื่อการสมัครใช้บริการเข้าสู่การระงับบัญชี เรียกใช้เมธอด
purchases.subscriptionsv2.get
จากเซิร์ฟเวอร์แบ็กเอนด์ที่ปลอดภัยเพื่อดึงข้อมูลการสมัครใช้บริการใหม่ ในระหว่างการระงับบัญชี ระบบจะตั้งค่าฟิลด์ expiryTime
ของทรัพยากรการสมัครใช้บริการ
เป็นการประทับเวลาในอดีต และตั้งค่าฟิลด์ subscriptionState
เป็น
SUBSCRIPTION_STATE_ON_HOLD
:
{
"kind": "androidpublisher#subscriptionPurchaseV2",
...
"subscriptionState": "SUBSCRIPTION_STATE_ON_HOLD",
...
"lineItems": [
{
"productId": "sub_variant_plan01",
"expiryTime": timestamp_in_past,
...
}
],
}
หากต้องการกู้คืนสิทธิ์เข้าถึง ผู้ใช้ต้องแก้ไขวิธีการชำระเงิน Play จะแจ้งให้ผู้ใช้ที่บัญชีถูกระงับทราบว่าการชำระเงินถูกปฏิเสธ และคุณควรสนับสนุนให้ผู้ใช้แก้ไขวิธีการชำระเงินด้วย
หลังจากที่ผู้ใช้แก้ไขวิธีการชำระเงินแล้ว การสมัครใช้บริการจะกลับมาอยู่ในสถานะใช้งานอยู่
และคุณจะต้องกู้คืนสิทธิ์เข้าถึงเนื้อหาที่สมัครใช้บริการ ในกรณีนี้ โทเค็นการซื้อจะเหมือนกับก่อนที่การระงับบัญชีจะเริ่มขึ้น เนื่องจากระบบจะกู้คืนการซื้อเดียวกัน และคุณจะได้รับ RTDN ที่มีประเภท SUBSCRIPTION_RECOVERED
สำหรับการสมัครใช้บริการแบบผ่อนชำระ การชำระเงินอาจถูกปฏิเสธและมีการเรียกเก็บเงินอีกครั้ง เมื่อมีการพยายามชำระเงินแต่ละครั้ง
หลังจากกู้คืนแล้ว Play Billing Library จะส่งคืนการสมัครใช้บริการอีกครั้งผ่านเมธอด queryPurchasesAsync()
หากคุณใช้วิธีนี้เพื่อพิจารณาว่าผู้ใช้มีสิทธิ์สมัครใช้บริการหรือไม่ แอปควรจัดการการกู้คืนการสมัครใช้บริการจากการระงับบัญชีโดยอัตโนมัติ
รอข้อความ
SubscriptionNotification
ที่มีประเภท SUBSCRIPTION_RECOVERED
เพื่อรับการแจ้งเตือนเมื่อมีการกู้คืนการสมัครใช้บริการ
และผู้ใช้ควรได้รับสิทธิ์เข้าถึงอีกครั้ง หากคุณค้นหาการสมัครใช้บริการ
หลังจากได้รับการแจ้งเตือนนี้ ระบบจะตั้งค่าฟิลด์ expiryTime
เป็นการประทับเวลา
ในอนาคต และตั้งค่าฟิลด์ subscriptionState
เป็น
SUBSCRIPTION_STATE_ACTIVE
อีกครั้ง
{
"kind": "androidpublisher#subscriptionPurchaseV2",
...
"subscriptionState": "SUBSCRIPTION_STATE_ACTIVE",
...
"lineItems": [
{
"productId": "sub_variant_plan01",
"expiryTime": next_renewal_date,
...
}
],
}
หากผู้ใช้ไม่แก้ไขวิธีการชำระเงินก่อนสิ้นสุดระยะเวลาระงับบัญชี
คุณจะได้รับ RTDN ที่มีประเภท SUBSCRIPTION_CANCELED
แทน ดูวิธีการจัดการการยกเลิกได้ที่การยกเลิก เมื่อคุณ
ค้นหาการสมัครใช้บริการที่ยกเลิกด้วยวิธีนี้ ระบบจะตั้งค่าฟิลด์ expiryTime
ที่แสดงผลเป็น
การประทับเวลาในอดีต
{
"kind": "androidpublisher#subscriptionPurchaseV2",
...
"subscriptionState": "SUBSCRIPTION_STATE_CANCELED",
...
"lineItems": [
{
"productId": "sub_variant_plan01",
"expiryTime": timestamp_in_past,
...
}
],
}
ทันทีหลังจากที่คุณได้รับการแจ้งเตือนเรื่องการยกเลิกในระหว่างการระงับบัญชี คุณจะได้รับ RTDN ที่มีประเภท SUBSCRIPTION_EXPIRED
ด้วย เนื่องจากผู้ใช้ไม่มีสิทธิ์แบบชำระเงินแล้ว และการสมัครใช้บริการได้หยุดให้บริการเนื่องจากการยกเลิก
คุณจัดการการหมดอายุนี้ได้ตามปกติ
ผู้ใช้จะได้รับสิทธิ์เข้าถึงอีกครั้งโดยการซื้อแพ็กเกจการสมัครใช้บริการเดิมซ้ำ หรือแพ็กเกจอื่นๆ ที่คุณเสนอผ่านแอปในช่วงที่ระบบระงับบัญชีนับจากการซื้อครั้งแรก ในกรณีดังกล่าว ระบบจะออกโทเค็นการซื้อใหม่และส่งคืนค่าใหม่เป็นส่วนหนึ่งของSUBSCRIPTION_PURCHASED
เหตุการณ์ที่
แสดงอินสแตนซ์ใหม่นี้
การเข้าถึงและการกู้คืนการระงับบัญชี
รูปที่ 3 แสดงไทม์ไลน์ของการสมัครใช้บริการที่เข้าสู่การระงับบัญชีและ กู้คืนเมื่อผู้ใช้แก้ไขวิธีการชำระเงิน

เช่นเดียวกับตัวอย่างก่อนหน้า รูปที่ 4 แสดงไทม์ไลน์ของการสมัครใช้บริการ ที่เข้าสู่ระยะเวลาผ่อนผันก่อนที่จะเข้าสู่การระงับบัญชี จากนั้น จะกู้คืนได้ในขณะที่ถูกระงับ

สิ่งสำคัญที่ควรทราบมีดังนี้
- ก่อนที่การสมัครใช้บริการจะเข้าสู่การระงับบัญชี Google Play จะพยายามเรียกเก็บเงินจากวิธีการชำระเงินอีกครั้งเป็นเวลาสูงสุด 48 ชั่วโมง ผู้ใช้จะยังคงได้รับ สิทธิประโยชน์จากการสมัครใช้บริการในช่วงนี้ หลังจากช่วงเวลาลองอีกครั้งนี้ผ่านไป การสมัครใช้บริการจะเข้าสู่การระงับบัญชี และผู้ใช้จะเสีย สิทธิ์เข้าถึงสิทธิประโยชน์จากการสมัครใช้บริการ
- การสมัครใช้บริการจะเข้าสู่การระงับบัญชีโดยตรงเมื่อการสมัครใช้บริการ กลับมาทำงานต่อจากสถานะหยุดชั่วคราวโดยมีรูปแบบการชำระเงินที่ไม่สำเร็จ
- เมื่อการสมัครใช้บริการกู้คืนจากการระงับบัญชี ระบบจะรีเซ็ตวันที่ต่ออายุ
วันหมดอายุ
เมื่อการสมัครใช้บริการหมดอายุ ผู้ใช้ควรเสียสิทธิ์เข้าถึงการสมัครใช้บริการ ในกรณีดังกล่าว ระบบจะส่งข้อความ SubscriptionNotification
ที่มีประเภท SUBSCRIPTION_EXPIRED
เมื่อได้รับการแจ้งเตือนนี้ ให้ค้นหา Google Play Developer
API เพื่อรับทรัพยากรการสมัครใช้บริการล่าสุด
หลังจากยืนยันว่า subscriptionState
เป็น SUBSCRIPTION_STATE_EXPIRED
แล้ว
ให้นำสิทธิ์ออกและลงทะเบียนสถานะการซื้อเป็นไม่ถูกต้องในแบ็กเอนด์
แหล่งข้อมูลการติดตามจะมีลักษณะคล้ายกับตัวอย่างต่อไปนี้
{
"kind": "androidpublisher#subscriptionPurchaseV2",
...
"subscriptionState": "SUBSCRIPTION_STATE_EXPIRED",
...
"lineItems": [
{
"productId": "sub_variant_plan01",
"expiryTime": expiration_time_in_past,
...
}
],
}
การยกเลิก
ผู้ใช้สามารถยกเลิกการสมัครใช้บริการจากศูนย์การสมัครใช้บริการของ Play ได้ด้วยตนเอง
หรือระบบจะยกเลิกการสมัครใช้บริการโดยอัตโนมัติหากผู้ใช้ไม่กู้คืนบัญชีหลังจากถูกระงับบัญชี นักพัฒนาแอปยังทริกเกอร์การยกเลิกด้วย
purchases.subscriptionsv2.cancel
ได้ด้วย
เมื่อมีการยกเลิกการสมัครใช้บริการ ผู้ใช้จะยังคงมีสิทธิ์เข้าถึงเนื้อหาจนกว่าจะ
สิ้นสุดรอบการเรียกเก็บเงินปัจจุบัน เมื่อรอบการเรียกเก็บเงินสิ้นสุดลง ระบบควรเพิกถอนสิทธิ์เข้าถึง
การยกเลิกการสมัครใช้บริการแบบต่ออายุอัตโนมัติที่ไม่ได้เป็นการผ่อนชำระจะทริกเกอร์การแจ้งเตือน SUBSCRIPTION_CANCELED
เมื่อคุณได้รับการแจ้งเตือนนี้ แหล่งข้อมูลการสมัครใช้บริการที่ Google Play Developer API ส่งคืนจะมีช่อง subscriptionState
ตั้งค่าเป็น SUBSCRIPTION_STATE_CANCELED
และช่อง expiryTime
จะมีวันที่ที่ผู้ใช้ควรสูญเสียสิทธิ์เข้าถึงการสมัครใช้บริการ หากวันที่ดังกล่าวอยู่ในอดีต ผู้ใช้ควรเสียสิทธิ์ทันที กรณีนี้อาจเกิดขึ้นได้ เช่น หากผู้ใช้ยกเลิกการสมัครใช้บริการขณะที่บัญชีถูกระงับเนื่องจากการชำระเงินถูกปฏิเสธ
แหล่งข้อมูลการสมัครใช้บริการสำหรับการซื้อที่ยกเลิกแล้วจะมีลักษณะคล้ายกับตัวอย่างต่อไปนี้
{
"kind": "androidpublisher#subscriptionPurchaseV2",
...
"subscriptionState": "SUBSCRIPTION_STATE_CANCELED",
...
"lineItems": [
{
"productId": "sub_variant_plan01",
"expiryTime": expiration_time,
...
}
],
}
สำหรับการสมัครใช้บริการแบบผ่อนชำระ ระบบจะส่งSUBSCRIPTION_CANCELLATION_SCHEDULED
การแจ้งเตือนเมื่อผู้ใช้ยกเลิกในกรณีที่ยังมีการชำระเงิน
ในช่วงระยะเวลาผูกมัด การยกเลิกอยู่ระหว่างรอการดำเนินการและจะมีผลเมื่อ
ระยะเวลาผูกมัดปัจจุบันสิ้นสุดลง เมื่อได้รับการแจ้งเตือนนี้ แหล่งข้อมูลการสมัครใช้บริการที่ส่งคืนจาก Google Play Developer API จะมีฟิลด์
subscriptionState ตั้งค่าเป็น SUBSCRIPTION_STATE_ACTIVE
เนื่องจาก
การสมัครใช้บริการแบบผ่อนชำระจะยังคงใช้งานได้จนกว่าจะสิ้นสุดระยะเวลาผูกมัด
แต่มีออบเจ็กต์ pendingCancellation ที่ว่างเปล่าอยู่
ระบบจะส่งSUBSCRIPTION_CANCELED
การแจ้งเตือนตามด้วยSUBSCRIPTION_EXPIRED
เมื่อสิ้นสุดระยะเวลาข้อตกลง
แหล่งข้อมูลการสมัครใช้บริการสำหรับการซื้อการสมัครใช้บริการแบบผ่อนชำระที่ รอยกเลิกจะมีลักษณะคล้ายกับตัวอย่างต่อไปนี้
{
"kind": "androidpublisher#subscriptionPurchaseV2",
...
"subscriptionState": "SUBSCRIPTION_STATE_ACTIVE",
...
"lineItems": [
{
"productId": "sub_plan01",
"expiryTime": expiration_time,
"autoRenewingPlan": {
"autoRenewEnabled": true,
"recurringPrice": {
"currencyCode": "USD",
"units": "1",
"nanos": 990000000
},
"installmentDetails": {
"initialCommittedPaymentsCount": 6,
"remainingCommittedPaymentsCount": 5,
"pendingCancellation": {}
...
}
}
}
],
}
คุณดูฟิลด์ canceledStateContext
ในแหล่งข้อมูลการสมัครใช้บริการเพื่อดูสาเหตุที่การสมัครใช้บริการถูกยกเลิกได้ (เช่น การสมัครใช้บริการถูกยกเลิกโดยผู้ใช้ ระบบ หรือคุณ) หากผู้ใช้ยกเลิกการสมัครใช้บริการ คุณสามารถดูฟิลด์ userInitiatedCancellation
เพื่อดูสาเหตุที่ผู้ใช้ยกเลิกการสมัครใช้บริการได้ ซึ่งจะช่วยในการกำหนดกลยุทธ์การสื่อสาร
เมื่อมีการยกเลิกการสมัครใช้บริการแต่ยังไม่หมดอายุ ระบบจะยังแสดงการสมัครใช้บริการดังกล่าวจาก queryPurchasesAsync()
คุณอาจต้องการแสดงข้อความในแอปเพื่อแจ้งให้ผู้ใช้ทราบว่าระบบได้ยกเลิกการสมัครใช้บริการแล้วและระบุวันที่หมดอายุ
การเพิกถอน
การสมัครใช้บริการอาจถูกเพิกถอนได้ด้วยเหตุผลหลายประการ ซึ่งรวมถึงแบ็กเอนด์ของคุณ
เพิกถอนการสมัครใช้บริการโดยใช้
purchases.subscriptionsv2.revoke
หรือการซื้อถูกเรียกเก็บเงินคืน ในกรณีนี้ ให้เพิกถอนสิทธิ์ของผู้ใช้
ทันที ระบบจะส่งข้อความ SubscriptionNotification
ที่มีประเภท
SUBSCRIPTION_REVOKED
เมื่อเกิดเหตุการณ์นี้ เมื่อคุณได้รับการแจ้งเตือนนี้ resource ของการสมัครใช้บริการ
ที่ส่งคืนจาก Google Play Developer API จะมีฟิลด์ subscriptionState
ตั้งค่าเป็น SUBSCRIPTION_STATE_EXPIRED
ทรัพยากรการสมัครใช้บริการสำหรับการซื้อที่ถูกเพิกถอนจะมีลักษณะคล้ายตัวอย่างต่อไปนี้
{
"kind": "androidpublisher#subscriptionPurchaseV2",
...
"subscriptionState": "SUBSCRIPTION_STATE_EXPIRED",
...
"lineItems": [
{
"productId": "sub_variant_plan01",
"expiryTime": expiration_time,
...
}
]
}
การสมัครใช้บริการที่เลื่อนออกไป
มีสาเหตุหลายประการที่คุณอาจต้องการขยายสิทธิ์ของผู้ใช้
เช่น คุณอาจต้องการเสนอสิทธิ์เข้าถึงฟรีแก่ผู้ใช้เป็นโปรโมชันพิเศษ
เช่น ให้สิทธิ์เข้าถึงฟรี 1 สัปดาห์เมื่อซื้อภาพยนตร์ หรือให้สิทธิ์เข้าถึงฟรีแก่ลูกค้า
เพื่อแสดงความปรารถนาดี คุณสามารถใช้วิธีการ
purchases.subscriptions.defer
จาก Play Developer API เพื่อเลื่อนวันที่เรียกเก็บเงินครั้งถัดไปสำหรับการสมัครใช้บริการแบบต่ออายุอัตโนมัติ เมื่อดำเนินการนี้ ระบบจะส่งSubscriptionNotification
ข้อความที่มีประเภท SUBSCRIPTION_DEFERRED
ในระหว่างระยะเวลาที่เลื่อนออกไป
ผู้ใช้จะสมัครใช้บริการเนื้อหาของคุณโดยมีสิทธิ์เข้าถึงแบบเต็ม แต่จะไม่มีการเรียกเก็บเงิน ระบบจะอัปเดตวันที่ต่ออายุการสมัครใช้บริการเพื่อให้ตรงกับวันที่ใหม่
สำหรับแพ็กเกจแบบชำระเงินล่วงหน้า คุณสามารถใช้ API การเรียกเก็บเงินที่รอตัดบัญชีเพื่อเลื่อนเวลาหมดอายุได้
แหล่งข้อมูลการสมัครใช้บริการสำหรับการสมัครใช้บริการที่เลื่อนการเรียกเก็บเงินจะมีลักษณะคล้ายกับ ตัวอย่างต่อไปนี้
{
"kind": "androidpublisher#subscriptionPurchaseV2",
...
"subscriptionState": "SUBSCRIPTION_STATE_ACTIVE",
...
"lineItems": [
{
"productId": "sub_variant_plan01",
"expiryTime": timestamp_in_future,
...
}
],
}
การสมัครใช้บริการที่หยุดชั่วคราว
คุณสามารถลดการเลิกใช้งานโดยตั้งใจได้ด้วยการอนุญาตให้ผู้ใช้หยุดการสมัครใช้บริการไว้ชั่วคราว เมื่อเปิดใช้ฟีเจอร์หยุดชั่วคราว ผู้ใช้สามารถเลือกหยุดการสมัครใช้บริการไว้ชั่วคราวเป็นระยะเวลาระหว่าง 1 สัปดาห์ไปจนถึง 3 เดือน โดยขึ้นอยู่กับระยะเวลาตามรอบ
การสมัครใช้บริการแบบเรียกเก็บเงินซ้ำ | รายสัปดาห์ | รายเดือน | 3 เดือน | 6 เดือน | รายปี |
---|---|---|---|---|---|
ระยะเวลาหยุดชั่วคราวที่ใช้ได้* | 1 สัปดาห์ 2 สัปดาห์ 3 สัปดาห์ 4 สัปดาห์ |
1 เดือน 2 เดือน 3 เดือน |
1 เดือน 2 เดือน 3 เดือน |
1 เดือน 2 เดือน 3 เดือน |
ไม่มี |
การหยุดสมัครใช้บริการไว้ชั่วคราวจะมีผลเมื่อสิ้นสุดช่วงเวลาที่เรียกเก็บเงินปัจจุบันไปแล้วเท่านั้น โดยผู้ใช้จะไม่มีสิทธิ์เข้าถึงเนื้อหาที่สมัครใช้บริการขณะที่หยุดการสมัครใช้บริการไว้ชั่วคราว และจะไม่ต้องชำระเงินเพื่อต่ออายุ เมื่อสิ้นสุดระยะเวลาการหยุดชั่วคราว การสมัครใช้บริการจะกลับมาทำงานอีกครั้ง และ Google จะพยายามต่ออายุการสมัครใช้บริการ หากกลับมาทำงานอีกครั้งได้สำเร็จ การสมัครใช้บริการก็จะใช้งานได้ใหม่ หาก การกลับมาทำงานต่อไม่สำเร็จเนื่องจากปัญหาการชำระเงิน ผู้ใช้จะเข้าสู่สถานะการระงับบัญชีตามที่ แสดงในรูปที่ 5 และ 6


นอกจากนี้ ผู้ใช้ยังเลือกกลับมาสมัครใช้บริการต่อด้วยตนเองได้ทุกเมื่อในระหว่าง ระยะเวลาหยุดชั่วคราว ดังที่แสดงในรูปที่ 6 เมื่อผู้ใช้กลับมาใช้บริการด้วยตนเอง วันที่เรียกเก็บเงินจะเปลี่ยนเป็นวันที่กลับมาใช้บริการด้วยตนเอง
เมื่อมีการหยุดการสมัครใช้บริการของผู้ใช้ชั่วคราว Play Billing Library จะไม่แสดงผลการสมัครใช้บริการผ่านเมธอด queryPurchasesAsync()
หากกลับมาสมัครใช้บริการอีกครั้ง queryPurchasesAsync()
method
จะส่งคืนค่าอีกครั้ง
รอฟัง RTDN เพื่อให้ทราบเมื่อผู้ใช้หยุดการสมัครใช้บริการชั่วคราว การแจ้งเตือนเหล่านี้ยังช่วยให้คุณแจ้งให้ผู้ใช้ในแอปทราบว่าได้ หยุดการสมัครใช้บริการชั่วคราวและไม่มีสิทธิ์เข้าถึงได้ด้วย นอกจากนี้ คุณควรระบุวิธีให้ผู้ใช้กลับมาสมัครใช้บริการด้วยตนเองได้ทุกเมื่อโดยใช้ Deep Link ไปยัง Google Play
ระบบจะส่งข้อความ SubscriptionNotification
ที่มีประเภท SUBSCRIPTION_PAUSE_SCHEDULE_CHANGED
เมื่อผู้ใช้เริ่มหยุดการสมัครใช้บริการชั่วคราว
ในตอนนี้ ผู้ใช้ควรมีสิทธิ์เข้าถึงการสมัครใช้บริการจนถึงวันที่ต่ออายุครั้งถัดไป และทรัพยากรการสมัครใช้บริการ
มี autoRenewEnabled = true
ค่าของฟิลด์ subscriptionState
คือ SUBSCRIPTION_STATE_ACTIVE
ในตอนนี้
ระบบจะส่งSubscriptionNotification
ข้อความที่มีประเภท SUBSCRIPTION_PAUSED
เมื่อการหยุดชั่วคราวมีผล
เมื่อเกิดกรณีนี้ ผู้ใช้ควรเสียสิทธิ์เข้าถึงการสมัครใช้บริการ และทรัพยากรการสมัครใช้บริการจะมี autoRenewEnabled = true
และฟิลด์ subscriptionState
จะตั้งค่าเป็น SUBSCRIPTION_STATE_PAUSED
คุณดูได้ว่าระบบคาดว่าจะต่ออายุการสมัครใช้บริการอีกครั้งเมื่อใดโดยตรวจสอบออบเจ็กต์
PausedStateContext
ระบบจะส่งSubscriptionNotification
ข้อความที่มีประเภท SUBSCRIPTION_RENEWED
ในกรณีต่อไปนี้
การสมัครใช้บริการกลับมาทำงานต่อโดยอัตโนมัติเมื่อสิ้นสุดช่วงหยุดชั่วคราว
หรือหากผู้ใช้เลือกที่จะกลับมาสมัครใช้บริการด้วยตนเอง คุณควรจัดการเรื่องนี้
ตามที่อธิบายไว้ในการต่ออายุ
ระบบจะส่งข้อความ SubscriptionNotification
ที่มีประเภท SUBSCRIPTION_ON_HOLD
หาก
การชำระเงินไม่สำเร็จขณะพยายามกลับมาใช้การสมัครใช้บริการต่อหลังจากหยุดชั่วคราว
การระงับบัญชีควรได้รับการจัดการตามที่อธิบายไว้ในการระงับบัญชี
สมัครอีกครั้ง
สำหรับแพ็กเกจเริ่มต้นของการสมัครใช้บริการแบบต่ออายุใหม่อัตโนมัติ Google Play Store อาจแสดงปุ่มสมัครอีกครั้ง ปุ่มนี้ช่วยให้ผู้ใช้ได้รับสิทธิ์เข้าถึง การสมัครใช้บริการอีกครั้ง โดยอาจไม่ปรากฏด้วยเหตุผลหลายประการ เช่น เมื่อการสมัครใช้บริการหมดอายุไปนานแล้ว

แม้ว่าปุ่มจะมีป้ายกำกับเป็นสมัครใช้บริการอีกครั้งเสมอ แต่ฟังก์ชันการทำงานจะขึ้นอยู่กับ สถานะการสมัครใช้บริการ
ในขณะที่การสมัครใช้บริการถูกยกเลิกแต่ยังไม่หมดอายุ ผู้ใช้จะยังคง สมัครใช้บริการและรับสิทธิประโยชน์จากการสมัครใช้บริการได้ หากผู้ใช้แตะ "สมัครใช้บริการอีกครั้ง" การยกเลิกจะถูกยกเลิก และการสมัครใช้บริการจะต่ออายุต่อไป การดำเนินการนี้เรียกว่ากู้คืนในเอกสารประกอบสำหรับนักพัฒนาแอปและ API ของ Play
หลังจากที่การสมัครใช้บริการแบบต่ออายุใหม่อัตโนมัติหมดอายุแล้ว คุณสามารถอนุญาตให้ผู้ใช้ซื้อ แพ็กเกจเริ่มต้นของการสมัครใช้บริการเดียวกันได้ การดำเนินการนี้เรียกว่าสมัครใช้บริการอีกครั้งใน เอกสารประกอบสำหรับนักพัฒนาแอป Play และ API คุณสามารถกำหนดค่าตัวเลือกนี้ สำหรับแต่ละแพ็กเกจเริ่มต้นใน Play Console หรือใช้ API
กู้คืนก่อนหมดอายุ
หากแอปของคุณใช้เฉพาะเมธอด
queryPurchasesAsync()
เพื่อพิจารณาว่าผู้ใช้มีสิทธิ์สมัครใช้บริการหรือไม่ แอปของคุณ
ควรจัดการการคืนค่าโดยอัตโนมัติเนื่องจากเมธอด queryPurchasesAsync()
จะยังคงแสดงผลการซื้อที่ยกเลิกก่อนวันที่หมดอายุ
การสมัครใช้บริการที่กู้คืนจะต่ออายุต่อไปราวกับว่าไม่ได้ถูกยกเลิก
หากแอปซิงค์สถานะการสมัครใช้บริการกับแบ็กเอนด์ คุณควรฟังข้อความ SubscriptionNotification
ที่มีประเภท SUBSCRIPTION_RESTARTED
หลังจากได้รับ RTDN นี้
แอปจะตอบกลับการแจ้งเตือน บันทึกว่าตอนนี้ระบบได้ตั้งค่าการสมัครใช้บริการให้ต่ออายุแล้ว
และหยุดแสดงข้อความการคืนค่าในแอปได้ โดยทรัพยากรการสมัครใช้บริการจะมีลักษณะคล้ายกับตัวอย่างต่อไปนี้
{
"kind": "androidpublisher#subscriptionPurchaseV2",
...
"subscriptionState": "SUBSCRIPTION_STATE_ACTIVE",
...
"lineItems": [
{
"productId": "sub_variant_plan01",
"expiryTime": next_renewal_date
...
}
],
}
สมัครใช้บริการอีกครั้งหลังจากหมดอายุ
หากกำหนดค่าแพ็กเกจเริ่มต้นแบบต่ออายุใหม่อัตโนมัติโดยใช้ Google Play Console หรือ API เพื่ออนุญาตให้สมัครอีกครั้ง ผู้ใช้จะซื้อการสมัครใช้บริการที่หมดอายุแล้วอีกครั้งได้ใน Google Play Store
นี่คือการซื้อใหม่ Google Play จะออกโทเค็นการซื้อใหม่ และแบ็กเอนด์ของคุณจะได้รับ RTDN ที่มีประเภท SUBSCRIPTION_PURCHASED
สถานะการซื้อ
สำหรับการซื้อนอกแอปประเภทนี้จะไม่รวม linkedPurchaseToken
ที่เชื่อมโยงกับการซื้อเดิมในกรณีดังกล่าว เนื่องจาก
การสมัครใช้บริการเดิมหมดอายุไปแล้ว การซื้อเหล่านี้เป็นการซื้อใหม่ที่แบ็กเอนด์ของคุณต้อง
ประมวลผลและรับทราบเช่นเดียวกับการซื้ออื่นๆ
อัปเกรด ดาวน์เกรด และสมัครใช้บริการอีกครั้ง
เมื่อผู้ใช้อัปเกรด ดาวน์เกรด หรือลงชื่อสมัครใช้หลังจาก ยกเลิกจากแอปของคุณก่อนที่การสมัครใช้บริการจะหมดอายุ ระบบจะทำให้การสมัครใช้บริการเก่า ไม่ถูกต้องและสร้างการสมัครใช้บริการใหม่พร้อม โทเค็นการซื้อใหม่
นอกจากนี้ resource การสมัครใช้บริการ
ที่ส่งคืนจาก Google Play Developer API ยังมีฟิลด์ linkedPurchaseToken
ซึ่งระบุการซื้อครั้งก่อนที่ผู้ใช้อัปเกรด ดาวน์เกรด
หรือสมัครใช้บริการอีกครั้ง คุณสามารถใช้โทเค็นการซื้อในช่องนั้นเพื่อค้นหาข้อมูลการสมัครใช้บริการเดิม
และระบุบัญชีผู้ใช้ที่มีอยู่ เพื่อให้คุณเชื่อมโยง
การซื้อใหม่กับบัญชีเดียวกันได้
ก่อนที่จะเสนอตัวเลือกการอัปเกรด ดาวน์เกรด หรือสมัครใช้บริการอีกครั้งให้แก่ผู้ใช้ในแอป คุณต้องรับทราบการสมัครใช้บริการที่มีอยู่ ระบบจะบล็อกการเปลี่ยนแพ็กเกจหรือการสมัครใช้บริการอีกครั้ง หากการสมัครใช้บริการที่มีอยู่ยังรอการรับทราบ
หากผู้ใช้ซื้อการอัปเกรด ดาวน์เกรด หรือสมัครใช้บริการอีกครั้งสำเร็จ นี่คือการซื้อใหม่ที่คุณต้องรับทราบ วิธีที่แนะนำ ในการดำเนินการนี้คือการใช้ Google Play Developer API แหล่งข้อมูลการติดตามจะมีลักษณะคล้ายกับตัวอย่างต่อไปนี้
{
"kind": "androidpublisher#subscriptionPurchaseV2",
...
"subscriptionState": "SUBSCRIPTION_STATE_ACTIVE",
"linkedPurchaseToken": old_purchase_token,
...
"lineItems": [
{
"productId": "sub_variant_plan01",
"expiryTime": next_renewal_date,
"autoRenewingPlan": {
"autoRenewEnabled": true
}
}
],
}
การเปลี่ยนแปลงราคา
ดูข้อมูลเกี่ยวกับการเปลี่ยนราคาการสมัครใช้บริการแบบต่ออายุใหม่อัตโนมัติและการแจ้งเตือนผู้ใช้ เมื่อเหมาะสมได้ที่คู่มือแนวทางปฏิบัติแนะนำในการเปลี่ยนแปลงราคา
เมื่อมีการเพิ่มการเปลี่ยนแปลงราคาและมีการอัปเดตสถานะการเปลี่ยนแปลงราคา
คุณจะได้รับ SUBSCRIPTION_PRICE_CHANGE_UPDATED
RTDN คุณสามารถค้นหาข้อมูล
ปลายทาง purchases.subscriptionsv2.get เพื่อรับแหล่งข้อมูลการสมัครใช้บริการซึ่งจะมีรายละเอียดการเปลี่ยนแปลงราคาของแต่ละรายการ
ในการสมัครใช้บริการ
เมื่อมีการใช้การเปลี่ยนแปลงราคาสำหรับสมาชิกปัจจุบันเป็นการเลือกใช้ คุณจะได้รับ RTDN หากผู้ใช้ดำเนินการเพื่อยืนยันหรือปฏิเสธราคาใหม่
จัดการการยืนยันของผู้ใช้เกี่ยวกับการเปลี่ยนแปลงราคาแบบเลือกรับ
เมื่อผู้ใช้ยอมรับการขึ้นราคาค่าสมัครใช้บริการ คุณจะได้รับข้อความ SubscriptionNotification ที่มีประเภท
SUBSCRIPTION_PRICE_CHANGE_UPDATED
จัดการการต่ออายุหลังจากใช้การเปลี่ยนแปลงราคา
เมื่อราคาลดลงหรือเมื่อการต่ออายุการสมัครใช้บริการที่มีการขึ้นราคา
คุณจะได้รับข้อความ SubscriptionNotification
ที่มีประเภท
SUBSCRIPTION_RENEWED
ถือว่าการแจ้งเตือนนี้เป็นการต่ออายุเช่นเดียวกับรายการอื่นๆ
จัดการกรณีที่ผู้ใช้ไม่ยอมรับการขึ้นราคาแบบขอให้ผู้ใช้ยินยอม
หากผู้ใช้ไม่ยอมรับการขึ้นราคาแบบขอให้ผู้ใช้ยินยอมก่อนที่จะต้องต่ออายุในราคาที่สูงขึ้น ระบบจะยกเลิกการสมัครใช้บริการของผู้ใช้โดยอัตโนมัติ
และคุณจะได้รับข้อความ SubscriptionNotification
ที่มีประเภท SUBSCRIPTION_CANCELED
จัดการเหตุการณ์นี้ตามที่อธิบายไว้ใน
การยกเลิก
นอกจากนี้ ผู้ใช้ยังยกเลิกการสมัครใช้บริการเพื่อเลือกไม่รับการขึ้นราคาได้ โดยใช้กลไกเดียวกัน
ความยินยอมในการปรับขึ้นราคา (ใช้ได้กับภูมิภาคเกาหลีเท่านั้น)
เนื่องจากกฎระเบียบใหม่ของเกาหลีใต้ (KR) ผู้ใช้การสมัครใช้บริการในภูมิภาค KR ต้องยินยอมการปรับขึ้นราคาที่จะเกิดขึ้นหลังจากช่วงทดลองใช้ฟรี หรือช่วงแนะนำสิ้นสุดลง
Play จะแจ้งให้ผู้ใช้ในภูมิภาคเกาหลีทราบถึงข้อกำหนดด้านความยินยอมและจะจัดเก็บการตอบกลับความยินยอมจากผู้ใช้ด้วย เพื่อช่วยให้คุณปฏิบัติตามกฎระเบียบได้ ระบบจะยกเลิกการสมัครใช้บริการโดยอัตโนมัติสำหรับผู้ใช้ ที่ไม่ได้ให้ความยินยอมก่อนที่ราคาที่สูงขึ้นจะมีผล นอกจาก การแจ้งเตือนที่ส่งจาก Play แล้ว คุณยังส่งการแจ้งเตือนการปรับราคาขึ้นแบบกำหนดเอง ให้ผู้ใช้ และระบุลิงก์ไปยัง หน้าการจัดการที่เฉพาะเจาะจงในการแจ้งเตือนได้ด้วย
เมื่อระยะเวลาขอความยินยอมเริ่มต้นขึ้นหรือผู้ใช้ให้ความยินยอมแล้ว คุณจะได้รับข้อความ SubscriptionNotification ที่มีประเภท
SUBSCRIPTION_PRICE_STEP_UP_CONSENT_UPDATED
ความแตกต่างระหว่างการเพิ่มราคาและการเปลี่ยนแปลงราคา
price step-up
หมายถึงการขึ้นราคาการสมัครใช้บริการเนื่องจากมีการเปลี่ยนจากข้อเสนอระยะหนึ่งไปยังอีกระยะหนึ่ง
เช่น การสมัครใช้บริการที่เปลี่ยนจากช่วงทดลองใช้ฟรีเป็นราคาปกติ
อย่างไรก็ตาม price change
หมายถึงการอัปเดตราคาที่คุณ (นักพัฒนาแอป) เป็นผู้เริ่ม
สำหรับราคาแพ็กเกจเริ่มต้นของการสมัครใช้บริการ เช่น
การขึ้นราคาแบบขอให้ผู้ใช้ยินยอมหรือการขึ้นราคาแบบไม่ได้ขอให้ผู้ใช้ยินยอม
จัดการวงจรการใช้งานสำหรับแพ็กเกจแบบชำระล่วงหน้า
เช่นเดียวกับการสมัครใช้บริการต่ออายุใหม่อัตโนมัติ คุณต้องรับทราบแพ็กเกจแบบชำระเงินล่วงหน้าหลังจากการซื้อใหม่แต่ละครั้ง ในกรณีของแพ็กเกจแบบชำระเงินล่วงหน้า คุณต้อง ประมวลผลทั้งการซื้อครั้งแรกและการเติมเงินทั้งหมด เนื่องจากผู้ใช้ต้อง ผ่านขั้นตอนการซื้อทุกครั้ง
เนื่องจากแพ็กเกจแบบชำระล่วงหน้าอาจมีระยะเวลาสั้น จึงเป็นเรื่องสำคัญที่จะต้อง รับทราบการซื้อโดยเร็วที่สุด คุณต้องตอบรับแพ็กเกจแบบชำระเงินล่วงหน้าที่มีระยะเวลา 1 สัปดาห์ขึ้นไปภายใน 3 วัน คุณต้องรับทราบแพ็กเกจแบบชำระล่วงหน้าที่มีระยะเวลาน้อยกว่า 1 สัปดาห์ภายในครึ่งหนึ่งของระยะเวลาแพ็กเกจ ตัวอย่างเช่น นักพัฒนาแอปมีเวลา 1.5 วันในการรับทราบการซื้อ แพ็กเกจแบบชำระเงินล่วงหน้า 3 วัน
ระบบจะส่งข้อความ SubscriptionNotification
ที่มีประเภท SUBSCRIPTION_PURCHASED
ไปยังไคลเอ็นต์ RTDN ทุกครั้งที่มีการซื้อ
การสมัครใช้บริการแพ็กเกจแบบชำระเงินล่วงหน้า รวมถึงการเติมเงินทุกครั้ง เรียกใช้เมธอด
purchases.subscriptionsv2.get
เพื่อตรวจสอบสถานะการสมัครใช้บริการแพ็กเกจแบบชำระล่วงหน้าล่าสุด
ระบบจะออกโทเค็นการซื้อใหม่สำหรับการซื้อการเติมเงิน และคุณจะได้รับโทเค็นการซื้อก่อนหน้าในฟิลด์ linkedPurchaseToken
ซึ่งเป็นส่วนหนึ่งของสถานะการซื้อการสมัครใช้บริการใหม่
โทเค็นการซื้อจะใช้ได้ตั้งแต่การลงชื่อสมัครใช้
จนถึง 60 วันหลังจากการสมัครใช้บริการหมดอายุ หลังจากวันที่ดังกล่าว โทเค็นการซื้อจะ
ใช้เรียก Google Play Developer API ไม่ได้อีกต่อไป
แหล่งข้อมูลการสมัครใช้บริการสำหรับการซื้อแพ็กเกจแบบชำระเงินล่วงหน้าจะมีลักษณะคล้ายกับตัวอย่างต่อไปนี้
{
"kind": "androidpublisher#subscriptionPurchaseV2",
"startTime": "2022-04-22T18:39:58.270Z",
"regionCode": "US",
"subscriptionState": "SUBSCRIPTION_STATE_ACTIVE",
"latestOrderId": "GPA.3333-4137-0319-36762",
"acknowledgementState": "ACKNOWLEDGEMENT_STATE_ACKNOWLEDGED",
"lineItems": [
{
"productId": "prepaid_plan01",
"expiryTime": expiry_date,
"prepaidPlan": {
"allowExtendAfterTime": timestamp_after_which_topups_are_allowed
}
}
]
}
คุณดูวันที่สิ้นสุดการให้สิทธิ์ได้ในช่องexpiryTime
การซื้อแพ็กเกจเติมเงิน
จะเพิ่มเวลาการให้สิทธิ์โดยการสะสมเวลา ซึ่งหมายความว่าหากผู้ใช้เติมเงินก่อนที่สิทธิ์เดิมจะสิ้นสุดลง ระบบจะเพิ่มเวลาใหม่
ต่อจากวันที่หมดอายุก่อนหน้า
คุณอาจต้องการแสดงข้อความในแอปเพื่อแจ้งให้ผู้ใช้ทราบว่าสามารถต่ออายุการสมัครใช้บริการแบบชำระล่วงหน้าได้ด้วยการเติมเงิน หากต้องการทราบว่าเมื่อใดที่ผู้ใช้จะเติมเงินได้ ให้ตรวจสอบฟิลด์ allowExtendAfterTime
ในทรัพยากรการสมัครใช้บริการ
แพ็กเกจแบบชำระเงินล่วงหน้าจะไม่ต่ออายุอัตโนมัติ จึงยกเลิกไม่ได้ หากผู้ใช้ต้องการยกเลิกแพ็กเกจแบบชำระเงินล่วงหน้า ผู้ใช้สามารถปล่อยให้แพ็กเกจหมดอายุได้
ฟิลด์ SubscriptionPurchaseV2 สำหรับแพ็กเกจแบบชำระเงินล่วงหน้า
เราได้เพิ่มฟิลด์ใหม่เพื่อรองรับแพ็กเกจแบบชำระเงินล่วงหน้า ซึ่งผู้ใช้จะเป็นผู้ขยายเวลาแทนที่จะต่ออายุอัตโนมัติ ฟิลด์ทั้งหมดใช้ได้กับแพ็กเกจแบบชำระเงินล่วงหน้าเช่นเดียวกับการสมัครใช้บริการแบบต่ออายุใหม่อัตโนมัติ โดยมีข้อยกเว้นดังนี้
- [ฟิลด์ใหม่] lineItems[0].prepaid_plan.allowExtendAfterTime: ระบุ เวลาที่ระบบจะอนุญาตให้ผู้ใช้ซื้อการเติมเงินอีกครั้งเพื่อขยายแพ็กเกจแบบชำระเงินล่วงหน้า เนื่องจากระบบอนุญาตให้ผู้ใช้มีการเติมเงินที่ยังไม่ได้ใช้เพียงรายการเดียวในแต่ละครั้ง
- [ฟิลด์ใหม่] SubscriptionState: ระบุสถานะออบเจ็กต์การสมัครใช้บริการ
สำหรับแพ็กเกจแบบชำระเงินล่วงหน้า ค่านี้จะเป็น
ACTIVE
,PENDING
หรือCANCELED
เสมอ - lineItems[0].expiryTime: ฟิลด์นี้จะแสดงเสมอสำหรับแพ็กเกจแบบชำระล่วงหน้า
- paused_state_context: ฟิลด์นี้จะไม่มีอยู่เนื่องจากแพ็กเกจแบบชำระล่วงหน้า หยุดชั่วคราวไม่ได้
- lineItems[0].auto_renewing_plan: ไม่มีสำหรับแพ็กเกจแบบชำระเงินล่วงหน้า
- canceled_state_context: ไม่มีสำหรับแพ็กเกจแบบชำระล่วงหน้า เนื่องจากฟิลด์นี้ ใช้ได้กับผู้ใช้ที่ยกเลิกการสมัครใช้บริการอย่างแข็งขันเท่านั้น
- lineItems[0].productId: ฟิลด์นี้จะแทนที่
subscriptionId
จาก เวอร์ชันก่อนหน้า