iOS - 應用內購買



應用內購買用於購買應用程式的附加內容或升級功能。

涉及的步驟

步驟 1 - 在 iTunes Connect 中,確保您擁有一個唯一的 App ID,並且當我們建立應用程式更新時,使用bundle ID 和 Xcode 中的程式碼簽名以及相應的配置檔案。

步驟 2 - 建立一個新應用程式並更新應用程式資訊。您可以在 Apple 的新增新應用文件中瞭解更多資訊。

步驟 3 - 在應用程式頁面中的管理應用內購買中為應用內購買新增新產品。

步驟 4 - 確保您設定了應用程式的銀行詳細資訊。這需要為應用內購買設定才能工作。此外,使用應用的 iTunes Connect 頁面中的管理使用者選項建立一個測試使用者帳戶。

步驟 5 - 下一步與處理程式碼和為我們的應用內購買建立 UI 相關。

步驟 6 - 建立一個單檢視應用程式,並輸入在 iTunes Connect 中指定的 bundle identifier。

步驟 7 - 更新ViewController.xib,如下所示 -

iOS Tutorial

步驟 8 - 為三個標籤和按鈕建立IBOutlets,分別命名為 productTitleLabel、productDescriptionLabel、productPriceLabel 和 purchaseButton。

步驟 9 - 選擇您的專案檔案,然後選擇目標,然後新增StoreKit.framework

步驟 10 - 更新ViewController.h,如下所示 -

#import <UIKit/UIKit.h>
#import <StoreKit/StoreKit.h>

@interface ViewController : UIViewController<
SKProductsRequestDelegate,SKPaymentTransactionObserver> {
   SKProductsRequest *productsRequest;
   NSArray *validProducts;
   UIActivityIndicatorView *activityIndicatorView;
   IBOutlet UILabel *productTitleLabel;
   IBOutlet UILabel *productDescriptionLabel;
   IBOutlet UILabel *productPriceLabel;
   IBOutlet UIButton *purchaseButton;
}

- (void)fetchAvailableProducts;
- (BOOL)canMakePurchases;
- (void)purchaseMyProduct:(SKProduct*)product;
- (IBAction)purchase:(id)sender;

@end

步驟 11 - 更新ViewController.m,如下所示 -

#import "ViewController.h"
#define kTutorialPointProductID 
@"com.tutorialPoints.testApp.testProduct"

@interface ViewController ()
@end

@implementation ViewController

- (void)viewDidLoad {
   [super viewDidLoad];
   
   // Adding activity indicator
   activityIndicatorView = [[UIActivityIndicatorView alloc]
   initWithActivityIndicatorStyle:UIActivityIndicatorViewStyleWhiteLarge];
   activityIndicatorView.center = self.view.center;
   [activityIndicatorView hidesWhenStopped];
   [self.view addSubview:activityIndicatorView];
   [activityIndicatorView startAnimating];
   
   //Hide purchase button initially
   purchaseButton.hidden = YES;
   [self fetchAvailableProducts];
}

- (void)didReceiveMemoryWarning {
   [super didReceiveMemoryWarning];
   // Dispose of any resources that can be recreated.
}

-(void)fetchAvailableProducts {
   NSSet *productIdentifiers = [NSSet 
   setWithObjects:kTutorialPointProductID,nil];
   productsRequest = [[SKProductsRequest alloc] 
   initWithProductIdentifiers:productIdentifiers];
   productsRequest.delegate = self;
   [productsRequest start];
}

- (BOOL)canMakePurchases {
   return [SKPaymentQueue canMakePayments];
}

- (void)purchaseMyProduct:(SKProduct*)product {
   if ([self canMakePurchases]) {
      SKPayment *payment = [SKPayment paymentWithProduct:product];
      [[SKPaymentQueue defaultQueue] addTransactionObserver:self];
      [[SKPaymentQueue defaultQueue] addPayment:payment];
   } else {
      UIAlertView *alertView = [[UIAlertView alloc]initWithTitle:
      @"Purchases are disabled in your device" message:nil delegate:
      self cancelButtonTitle:@"Ok" otherButtonTitles: nil];
      [alertView show];
   }
}
-(IBAction)purchase:(id)sender {
   [self purchaseMyProduct:[validProducts objectAtIndex:0]];
   purchaseButton.enabled = NO; 
}

#pragma mark StoreKit Delegate

-(void)paymentQueue:(SKPaymentQueue *)queue 
updatedTransactions:(NSArray *)transactions {
   for (SKPaymentTransaction *transaction in transactions) {
      switch (transaction.transactionState) {
         case SKPaymentTransactionStatePurchasing:
            NSLog(@"Purchasing");
         break;
         
         case SKPaymentTransactionStatePurchased:
            if ([transaction.payment.productIdentifier 
            isEqualToString:kTutorialPointProductID]) {
               NSLog(@"Purchased ");
               UIAlertView *alertView = [[UIAlertView alloc]initWithTitle:
               @"Purchase is completed succesfully" message:nil delegate:
               self cancelButtonTitle:@"Ok" otherButtonTitles: nil];
               [alertView show];
            }
            [[SKPaymentQueue defaultQueue] finishTransaction:transaction];
         break;
            
         case SKPaymentTransactionStateRestored:
            NSLog(@"Restored ");
            [[SKPaymentQueue defaultQueue] finishTransaction:transaction];
         break;
            
         case SKPaymentTransactionStateFailed:
            NSLog(@"Purchase failed ");
         break
         default:
         break;
      }
   }
}

-(void)productsRequest:(SKProductsRequest *)request 
didReceiveResponse:(SKProductsResponse *)response {
   SKProduct *validProduct = nil;
   int count = [response.products count];
   
   if (count>0) {
      validProducts = response.products;
      validProduct = [response.products objectAtIndex:0];
      
      if ([validProduct.productIdentifier 
         isEqualToString:kTutorialPointProductID]) {
         [productTitleLabel setText:[NSString stringWithFormat:
            @"Product Title: %@",validProduct.localizedTitle]];
         [productDescriptionLabel setText:[NSString stringWithFormat:
            @"Product Desc: %@",validProduct.localizedDescription]];
         [productPriceLabel setText:[NSString stringWithFormat:
            @"Product Price: %@",validProduct.price]];
      }
   } else {
      UIAlertView *tmp = [[UIAlertView alloc]
         initWithTitle:@"Not Available"
         message:@"No products to purchase"
         delegate:self
         cancelButtonTitle:nil
         otherButtonTitles:@"Ok", nil];
         [tmp show];
   }
   
   [activityIndicatorView stopAnimating];
   purchaseButton.hidden = NO;
}
@end

注意

您必須將 kTutorialPointProductID 更新為為應用內購買建立的產品 ID。您可以透過更新 fetchAvailableProducts 中的 productIdentifiers 的 NSSet 來新增多個產品。類似地,處理您新增的產品 ID 的購買相關操作。

輸出

當我們執行應用程式時,我們將獲得以下輸出 -

iOS Tutorial

確保您已在設定螢幕中登出帳戶。點選“開始購買”後,選擇“使用現有 Apple ID”。輸入您的有效測試帳戶使用者名稱和密碼。幾秒鐘後,您將看到以下警報。

iOS Tutorial

成功購買產品後,您將收到以下警報。您可以看到更新應用程式功能的相關程式碼,我們在此顯示此警報。

iOS Tutorial
廣告

© . All rights reserved.