data:image/s3,"s3://crabby-images/ac475/ac475efbd8de76df75ed383044bd671c3d3bfc93" alt="IMG_4304.JPG"
1.下面是我自己畫的一個大概的流程圖(字比較爛,將就這看吧哈~)
data:image/s3,"s3://crabby-images/1cbf8/1cbf832660cf745621cb77dfb3940fd3c74aa942" alt="IMG_6284.JPG"
圖中 ① 為請求商品詳情之後根據商品的ID 發起支付請求 (這裡的Id 就是商品的ProductId)
data:image/s3,"s3://crabby-images/8cfae/8cfaed04b9ccaa472306a4dd1429ec27cef281c0" alt="1.png"
data:image/s3,"s3://crabby-images/259db/259dbc4eef697d0b6c69ddf397790b2eff6be28e" alt="In-App Purchase 內購丟單、串單處理"
data:image/s3,"s3://crabby-images/32653/3265324f04e5b90fe2b859191641fcfd0cf3c2ae" alt="In-App Purchase 內購丟單、串單處理"
然後是圖中② 在收到蘋果返回的支付結果後做的處理
data:image/s3,"s3://crabby-images/195b6/195b6d2e4b7edef75a4ed43b77f205d05f6b1342" alt="3.png"
這裡會收到蘋果支付的返回憑證,這裡要做下本地儲存,防止傳送後臺失敗引起的丟單。
data:image/s3,"s3://crabby-images/3c4c2/3c4c2f5f18136fd0e3ac46e84935605d3a621a9b" alt="4.png"
data:image/s3,"s3://crabby-images/113a8/113a895b9917f12ccf8bcbf0bae3db4cb759fb92" alt="5.png"
2.丟單產生的情況和處理
1.在①的時候重點是在封裝的時候把訂單資訊寫進SKMutablePayment,這樣在收到支付結果的時候就可以去取出這個訂單號,傳送後臺進行驗證,這樣就能有效的規避串單問題。 2.在②的時候在使用者支付之後還未收到憑證回撥之後如果app 出現異常,就不能正常接收支付結果的回撥,這個時候,只要不主動關閉這次交易事務下次設定監聽的時候(建議重啟的時候),還是可以獲取到這次交易回撥,再進行憑證處理。
MyStoreObserver *tempObserver = [MyStoreObserver shareInstance];
self.observer = tempObserver;
[[SKPaymentQueue defaultQueue] addTransactionObserver:tempObserver];
複製程式碼
3.在③的時候收到憑證的回撥之後傳送後臺驗證這塊很可能會出現傳送失敗等情況,這個時候就要把憑證進行本地儲存(儲存的是記得是儲存為陣列,因為可能有多個),在驗證成功之後再刪除本地儲存的憑證。
丟單的處理在上面的貼圖程式碼中也有體現,希望對你會有幫助,大體總結就到這裡了,中午吃飯了,就這麼多吧! ?