iOS - 应用内购买
应用内购买用于购买与应用相关的附加内容或升级功能。
涉及的步骤
步骤 1 − 在 iTunes 连接中,确保您有一个唯一的 App ID,并且当我们使用 bundle ID 创建应用程序更新并在 Xcode 中使用相应的配置文件进行代码签名时。
步骤 2 − 创建一个新的应用程序并更新应用程序信息。 您可以在 Apple 的 Add new apps 添加新应用文档中了解更多信息。
步骤 3 − 在应用程序页面的 Manage In-App Purchase 管理应用内购买中添加新产品以进行应用内购买。
步骤 4 − 确保为您的应用程序设置银行详细信息。 这需要进行设置,In-App purchase 应用内购买才能正常工作。 此外,使用应用程序的 iTunes 连接页面中的 Manage Users 管理用户选项创建一个测试用户帐户。
步骤 5 − 接下来的步骤与处理代码和为我们的应用内购买创建 UI 有关。
步骤 6 − 创建一个 single view application 单视图应用程序并输入捆绑标识符是iTunes连接中指定的标识符。
步骤 7 − 如下所示更新 ViewController.xib −

步骤 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 更新为您为应用内购买创建的 productID。 您可以通过在 fetchAvailableProducts 中更新 productIdentifiers 的 NSSet 来添加多个产品。 同样,为您添加的产品 ID 处理购买相关操作。
输出
当我们运行应用程序时,我们会得到以下输出 −

确保您已在设置屏幕中注销您的帐户。 单击启动购买时,选择使用现有的 Apple ID。 输入您的有效测试帐户用户名和密码。 您将在几秒钟内看到以下警报。

一旦您的产品购买成功,您将收到以下提醒。 您可以在我们显示此警报的地方看到更新应用程序功能的相关代码。
